Skip to content

Commit

Permalink
fk test
Browse files Browse the repository at this point in the history
  • Loading branch information
dfava committed Sep 20, 2024
1 parent 75ca1ed commit fc7a21b
Showing 1 changed file with 46 additions and 24 deletions.
70 changes: 46 additions & 24 deletions querysql/querysql_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -480,37 +480,59 @@ func TestEmptyResultWithError(t *testing.T) {
}{
{
query: `
if OBJECT_ID('dbo.MyUsers', 'U') is not null drop table MyUsers
create table MyUsers (
if OBJECT_ID('dbo.MyUser', 'U') is not null drop table MyUser
create table MyUser (
ID INT IDENTITY(1,1) PRIMARY KEY,
Username NVARCHAR(50) not null,
Userage int
);
insert into MyUsers (Userage)
insert into MyUser (Userage)
output inserted.ID
values (42);
`,
expected: "mssql: Cannot insert the value NULL into column 'Username', table 'master.dbo.MyUsers'; column does not allow nulls. INSERT fails.",
expected: "mssql: Cannot insert the value NULL into column 'Username', table 'master.dbo.MyUser'; column does not allow nulls. INSERT fails.",
},
{
query: `
if OBJECT_ID('dbo.Department', 'U') is not null drop table Department
create table Department (
ID INT IDENTITY(1,1) PRIMARY KEY,
Name NVARCHAR(50) not null,
);
if OBJECT_ID('dbo.Employee', 'U') is not null drop table Employee
create table Employee (
ID INT IDENTITY(1,1) PRIMARY KEY,
Name NVARCHAR(50) not null,
Department int
constraint fk_Department foreign key references Employee(ID),
);
insert into Employee(Name, Department) values ('Bob', 1);
select @@rowcount;
`,
expected: "", // TODO(dsf)
},
}

for _, tc := range testcases {
// ExecContext error
_, errExec := ExecContext(context.Background(), sqldb, tc.query, "world")
assert.Error(t, errExec)
assert.Equal(t, tc.expected, errExec.Error())

// SingleOf error
rs := New(context.Background(), sqldb, tc.query)
_ = rs.Rows
_, errSingle := NextResult(rs, SingleOf[int])
assert.Error(t, errSingle)
// The errSingle has the same underlying error as the errExec
assert.True(t, errors.Is(errSingle, errExec))
// But the errSingle is not the same error as the errExec because,
// in addition to the underlying error, errSingle also contains
// the information that we called Single and didn't get any value back
assert.False(t, errors.Is(errExec, errSingle))
for i, tc := range testcases {
t.Run(fmt.Sprintf("%d:%s", i, tc.name), func(t *testing.T) {
// ExecContext error
_, errExec := ExecContext(context.Background(), sqldb, tc.query, "world")
require.Error(t, errExec)
require.Equal(t, tc.expected, errExec.Error())

// SingleOf error
rs := New(context.Background(), sqldb, tc.query)
_ = rs.Rows
_, errSingle := NextResult(rs, SingleOf[int])
assert.Error(t, errSingle)
// The errSingle has the same underlying error as the errExec
assert.True(t, errors.Is(errSingle, errExec))
// But the errSingle is not the same error as the errExec because,
// in addition to the underlying error, errSingle also contains
// the information that we called Single and didn't get any value back
assert.False(t, errors.Is(errExec, errSingle))
})
}
}

Expand Down Expand Up @@ -653,12 +675,12 @@ func TestStructScanError(t *testing.T) {

func TestExecContext(t *testing.T) {
qry := `
if OBJECT_ID('dbo.MyUsers', 'U') is not null drop table MyUsers
create table MyUsers (
if OBJECT_ID('dbo.MyUser', 'U') is not null drop table MyUser
create table MyUser (
ID INT IDENTITY(1,1) PRIMARY KEY,
Username NVARCHAR(50)
);
insert into MyUsers (Username) values ('JohnDoe');
insert into MyUser (Username) values ('JohnDoe');
-- logging
select _log='info', Y = 'one';
Expand Down

0 comments on commit fc7a21b

Please sign in to comment.