Skip to content

Commit

Permalink
Fix update UpdatedAt when full saving associations, close go-gorm#4115
Browse files Browse the repository at this point in the history
  • Loading branch information
jinzhu committed Feb 26, 2021
1 parent 189547f commit eb9a704
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 1 deletion.
5 changes: 5 additions & 0 deletions callbacks/associations.go
Original file line number Diff line number Diff line change
Expand Up @@ -361,6 +361,7 @@ func saveAssociations(db *gorm.DB, rel *schema.Relationship, values interface{},
}

tx := db.Session(&gorm.Session{NewDB: true}).Clauses(onConflict).Session(&gorm.Session{
FullSaveAssociations: db.FullSaveAssociations,
SkipHooks: db.Statement.SkipHooks,
DisableNestedTransaction: true,
})
Expand All @@ -370,6 +371,10 @@ func saveAssociations(db *gorm.DB, rel *schema.Relationship, values interface{},
return true
})

if tx.Statement.FullSaveAssociations {
tx = tx.InstanceSet("gorm:update_track_time", true)
}

if len(selects) > 0 {
tx = tx.Select(selects)
} else if len(selectColumns) > 0 && len(omits) == 0 {
Expand Down
5 changes: 5 additions & 0 deletions callbacks/create.go
Original file line number Diff line number Diff line change
Expand Up @@ -320,6 +320,11 @@ func ConvertToCreateValues(stmt *gorm.Statement) (values clause.Values) {
field.Set(stmt.ReflectValue, curTime)
values.Values[0][idx], _ = field.ValueOf(stmt.ReflectValue)
}
} else if field.AutoUpdateTime > 0 {
if _, ok := stmt.DB.InstanceGet("gorm:update_track_time"); ok {
field.Set(stmt.ReflectValue, curTime)
values.Values[0][idx], _ = field.ValueOf(stmt.ReflectValue)
}
}
}

Expand Down
12 changes: 11 additions & 1 deletion tests/update_has_one_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package tests_test

import (
"testing"
"time"

"gorm.io/gorm"
. "gorm.io/gorm/utils/tests"
Expand Down Expand Up @@ -31,15 +32,24 @@ func TestUpdateHasOne(t *testing.T) {

var user3 User
DB.Preload("Account").Find(&user3, "id = ?", user.ID)

CheckUser(t, user2, user3)
var lastUpdatedAt = user2.Account.UpdatedAt
time.Sleep(time.Second)

if err := DB.Session(&gorm.Session{FullSaveAssociations: true}).Save(&user).Error; err != nil {
t.Fatalf("errors happened when update: %v", err)
}

var user4 User
DB.Preload("Account").Find(&user4, "id = ?", user.ID)
CheckUser(t, user4, user)

if lastUpdatedAt.Format(time.RFC3339) == user4.Account.UpdatedAt.Format(time.RFC3339) {
t.Fatalf("updated at should be updated, but not, old: %v, new %v", lastUpdatedAt.Format(time.RFC3339), user3.Account.UpdatedAt.Format(time.RFC3339))
} else {
user.Account.UpdatedAt = user4.Account.UpdatedAt
CheckUser(t, user4, user)
}

t.Run("Polymorphic", func(t *testing.T) {
var pet = Pet{Name: "create"}
Expand Down

0 comments on commit eb9a704

Please sign in to comment.