From ed5dce528750a790c8d73f794ae53760a6e3e6a5 Mon Sep 17 00:00:00 2001 From: Mike Thompson Date: Mon, 7 Apr 2014 15:02:48 -0700 Subject: [PATCH] Initial test to show failure This initial test, against this code base, shows that "update" against a table, with only one column, where that coumn is the primary key, and is not auto-incrementing, will fail. --- gorp_test.go | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/gorp_test.go b/gorp_test.go index e0eb5aca..3a426344 100644 --- a/gorp_test.go +++ b/gorp_test.go @@ -125,6 +125,10 @@ type UniqueColumns struct { ZipCode int64 } +type SingleColumnTable struct { + SomeId string +} + type testTypeConverter struct{} func (me testTypeConverter) ToDb(val interface{}) (interface{}, error) { @@ -1491,6 +1495,37 @@ func TestMysqlPanicIfDialectNotInitialized(t *testing.T) { db.CreateTables() } +func TestSingleColumnKeyDbReturnsZeroRowsUpdatedOnPKChange(t *testing.T) { + dbmap := initDbMap() + defer dropAndClose(dbmap) + dbmap.AddTableWithName(SingleColumnTable{}, "single_column_table").SetKeys(false, "SomeId") + err := dbmap.DropTablesIfExists() + if err != nil { + t.Error("Drop tables failed") + } + err = dbmap.CreateTablesIfNotExists() + if err != nil { + t.Error("Create tables failed") + } + err = dbmap.TruncateTables() + if err != nil { + t.Error("Truncate tables failed") + } + + sct := SingleColumnTable{ + SomeId: "A Unique Id String", + } + + count, err := dbmap.Update(&sct) + if err != nil { + t.Error(err) + } + if count != 0 { + t.Errorf("Expected 0 updated rows, got %d", count) + } + +} + func BenchmarkNativeCrud(b *testing.B) { b.StopTimer() dbmap := initDbMapBench()