feat: 实现设备管理和设备导入功能,修复测试问题
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 5m30s
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 5m30s
主要变更: - 实现设备管理模块(创建、查询、列表、更新状态、删除) - 实现设备批量导入功能(CSV 解析、ICCID 绑定、异步任务处理) - 添加设备-SIM 卡绑定约束(部分唯一索引防止并发问题) - 修复 fee_rate 数据库字段类型(numeric -> bigint) - 修复测试数据隔离问题(基于增量断言) - 修复集成测试中间件顺序问题 - 清理无用测试文件(PersonalCustomer、Email 相关) - 归档 enterprise-card-authorization 变更
This commit is contained in:
@@ -355,58 +355,6 @@ func TestDataPermissionCallback_FilterForEnterprise(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
// TestDataPermissionCallback_FilterForPersonalCustomer 测试个人客户过滤
|
||||
func TestDataPermissionCallback_FilterForPersonalCustomer(t *testing.T) {
|
||||
// 创建内存数据库
|
||||
db, err := gorm.Open(sqlite.Open(":memory:"), &gorm.Config{})
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 创建测试表(包含 creator 字段)
|
||||
type TestModel struct {
|
||||
ID uint
|
||||
Creator uint
|
||||
Name string
|
||||
}
|
||||
|
||||
err = db.AutoMigrate(&TestModel{})
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 插入测试数据
|
||||
db.Create(&TestModel{ID: 1, Creator: 1, Name: "test1"})
|
||||
db.Create(&TestModel{ID: 2, Creator: 2, Name: "test2"})
|
||||
db.Create(&TestModel{ID: 3, Creator: 1, Name: "test3"})
|
||||
|
||||
// 创建 mock ShopStore(个人客户不需要,但注册时需要)
|
||||
mockStore := &mockShopStore{
|
||||
subordinateShopIDs: []uint{},
|
||||
}
|
||||
|
||||
// 注册 Callback
|
||||
err = RegisterDataPermissionCallback(db, mockStore)
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 设置个人客户 context
|
||||
ctx := context.Background()
|
||||
ctx = middleware.SetUserContext(ctx, &middleware.UserContextInfo{
|
||||
UserID: 1,
|
||||
UserType: constants.UserTypePersonalCustomer,
|
||||
ShopID: 0,
|
||||
EnterpriseID: 0,
|
||||
CustomerID: 1,
|
||||
})
|
||||
|
||||
// 查询数据
|
||||
var results []TestModel
|
||||
err = db.WithContext(ctx).Find(&results).Error
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 个人客户只能看到自己创建的数据
|
||||
assert.Equal(t, 2, len(results))
|
||||
for _, r := range results {
|
||||
assert.Equal(t, uint(1), r.Creator)
|
||||
}
|
||||
}
|
||||
|
||||
// ============================================================
|
||||
// 标签表数据权限过滤测试(tb_tag / tb_resource_tag 表)
|
||||
// ============================================================
|
||||
@@ -704,40 +652,6 @@ func TestTagPermission_Enterprise_NoEnterpriseID(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
// TestTagPermission_PersonalCustomer 测试个人客户查询标签
|
||||
// 预期:只能看到全局标签
|
||||
func TestTagPermission_PersonalCustomer(t *testing.T) {
|
||||
db, mockStore := setupTagTestDB(t)
|
||||
|
||||
// 注册 Callback
|
||||
err := RegisterDataPermissionCallback(db, mockStore)
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 设置个人客户 context
|
||||
ctx := context.Background()
|
||||
ctx = middleware.SetUserContext(ctx, &middleware.UserContextInfo{
|
||||
UserID: 1,
|
||||
UserType: constants.UserTypePersonalCustomer,
|
||||
ShopID: 0,
|
||||
EnterpriseID: 0,
|
||||
CustomerID: 1,
|
||||
})
|
||||
|
||||
// 查询标签
|
||||
var tags []TagModel
|
||||
err = db.WithContext(ctx).Find(&tags).Error
|
||||
assert.NoError(t, err)
|
||||
|
||||
// 个人客户只能看到 2 个全局标签
|
||||
assert.Equal(t, 2, len(tags), "个人客户只能看到全局标签")
|
||||
|
||||
// 验证都是全局标签
|
||||
for _, tag := range tags {
|
||||
assert.Nil(t, tag.EnterpriseID, "个人客户只能看到全局标签,enterprise_id 应为 NULL")
|
||||
assert.Nil(t, tag.ShopID, "个人客户只能看到全局标签,shop_id 应为 NULL")
|
||||
}
|
||||
}
|
||||
|
||||
// TestTagPermission_ResourceTag_Agent 测试代理用户查询资源标签表
|
||||
// 预期:与 tb_tag 表相同的过滤规则
|
||||
func TestTagPermission_ResourceTag_Agent(t *testing.T) {
|
||||
|
||||
Reference in New Issue
Block a user