Skip to content

Commit

Permalink
Fix TestMutationResolver_CreateCard
Browse files Browse the repository at this point in the history
  • Loading branch information
yasuflatland-lf committed Jul 13, 2024
1 parent 9845132 commit 96de1ee
Show file tree
Hide file tree
Showing 5 changed files with 103 additions and 46 deletions.
20 changes: 12 additions & 8 deletions backend/graph/schema.resolvers.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

75 changes: 64 additions & 11 deletions backend/graph/schema.resolvers_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"log"
"net/http"
"net/http/httptest"
"strings"
"testing"
"time"

Expand Down Expand Up @@ -73,23 +74,69 @@ func setupEchoServer(db *gorm.DB) *echo.Echo {
return e
}

func testGraphQLQuery(t *testing.T, e *echo.Echo, jsonInput []byte, expected string) {
func testGraphQLQuery(t *testing.T, e *echo.Echo, jsonInput []byte, expected string, ignoreFields ...string) {
req := httptest.NewRequest(http.MethodPost, "/query", bytes.NewBuffer(jsonInput))
req.Header.Set(echo.HeaderContentType, echo.MIMEApplicationJSON)
rec := httptest.NewRecorder()

e.ServeHTTP(rec, req)

assert.JSONEq(t, expected, rec.Body.String())
var actualResponse map[string]interface{}
var expectedResponse map[string]interface{}

// Parse the actual response
if err := json.Unmarshal(rec.Body.Bytes(), &actualResponse); err != nil {
t.Fatalf("Failed to unmarshal actual response: %v", err)
}

// Parse the expected response
if err := json.Unmarshal([]byte(expected), &expectedResponse); err != nil {
t.Fatalf("Failed to unmarshal expected response: %v", err)
}

// Remove the fields to ignore from both responses
for _, field := range ignoreFields {
removeField(actualResponse, field)
removeField(expectedResponse, field)
}

// Compare the modified responses
assert.Equal(t, expectedResponse, actualResponse)
}

func removeField(data map[string]interface{}, field string) {
// Split the field into parts if it's nested (e.g., data.createCard.created)
parts := strings.Split(field, ".")
current := data

for i, part := range parts {
if i == len(parts)-1 {
delete(current, part)
} else if next, ok := current[part].(map[string]interface{}); ok {
current = next
} else {
break
}
}
}

func TestMutationResolver_CreateCard(t *testing.T) {
// Step 1: Create a Cardgroup
now := time.Now()
cardgroup := repository.Cardgroup{
Name: "Test Cardgroup",
Created: now,
Updated: now,
}
db.Create(&cardgroup)

// Step 2: Create a new card with the CardgroupID
input := model.NewCard{
Front: "Front of card",
Back: "Back of card",
ReviewDate: time.Now(),
ReviewDate: now,
IntervalDays: new(int),
CardgroupID: 1,
CardgroupID: cardgroup.ID,
}
jsonInput, _ := json.Marshal(map[string]interface{}{
"query": `mutation ($input: NewCard!) {
Expand All @@ -107,15 +154,21 @@ func TestMutationResolver_CreateCard(t *testing.T) {
"input": input,
},
})
expected := `{
expected := fmt.Sprintf(`{
"data": {
"createCard": {
"front": "Front of card",
"back": "Back of card"
"back": "Back of card",
"review_date": "%s",
"interval_days": 1,
"created": "%s",
"updated": "%s",
"id": 1
}
}
}`
testGraphQLQuery(t, e, jsonInput, expected)
}`, cardgroup.Created.Format(time.RFC3339Nano), cardgroup.Created.Format(time.RFC3339Nano), cardgroup.Updated.Format(time.RFC3339Nano))

testGraphQLQuery(t, e, jsonInput, expected, "data.createCard.created", "data.createCard.updated")
}

func TestMutationResolver_UpdateCard(t *testing.T) {
Expand Down Expand Up @@ -162,7 +215,7 @@ func TestMutationResolver_UpdateCard(t *testing.T) {
}
}
}`
testGraphQLQuery(t, e, jsonInput, expected)
testGraphQLQuery(t, e, jsonInput, expected, "data.updateCard.created", "data.updateCard.updated")
}

func TestMutationResolver_DeleteCard(t *testing.T) {
Expand Down Expand Up @@ -228,7 +281,7 @@ func TestQueryResolver_Cards(t *testing.T) {
}]
}
}`
testGraphQLQuery(t, e, jsonInput, expected)
testGraphQLQuery(t, e, jsonInput, expected, "data.cards.created", "data.cards.updated")
}

func TestQueryResolver_Card(t *testing.T) {
Expand Down Expand Up @@ -268,7 +321,7 @@ func TestQueryResolver_Card(t *testing.T) {
}
}
}`
testGraphQLQuery(t, e, jsonInput, expected)
testGraphQLQuery(t, e, jsonInput, expected, "data.card.created", "data.card.updated")
}

// Add similar tests for the remaining resolvers
Expand Down
2 changes: 1 addition & 1 deletion backend/pkg/flashcard/flashcard_system.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ func CreateCardReview(card *model.Card, db *gorm.DB) error {
// MigrateDB performs the database migration for the Card struct
func MigrateDB(db *gorm.DB) error {
return db.AutoMigrate(
&model.CardGroup{},
&model.Cardgroup{},
&model.Card{},
&model.User{},
&model.Role{},
Expand Down
12 changes: 6 additions & 6 deletions backend/pkg/flashcard/flashcard_system_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,9 @@ func setupTestDB(t *testing.T) (*gorm.DB, func()) {
}
}

func createTestCardGroup(t *testing.T, db *gorm.DB, name string) model.CardGroup {
func createTestCardGroup(t *testing.T, db *gorm.DB, name string) model.Cardgroup {
t.Helper()
cardGroup := model.CardGroup{Name: name}
cardGroup := model.Cardgroup{Name: name}
if err := db.Create(&cardGroup).Error; err != nil {
t.Fatalf("could not create test card group: %v", err)
}
Expand Down Expand Up @@ -197,7 +197,7 @@ func TestFlashcardFunctions(t *testing.T) {
assert.True(t, card.Updated.After(createdTime))
})

t.Run("Test CardGroup Model", func(t *testing.T) {
t.Run("Test Cardgroup Model", func(t *testing.T) {
assert.NotZero(t, cardGroup.ID)
assert.Equal(t, "Test Group", cardGroup.Name)
assert.NotZero(t, cardGroup.Created)
Expand Down Expand Up @@ -225,14 +225,14 @@ func TestFlashcardFunctions(t *testing.T) {
user := createTestUser(t, db, "user2", "Relationship User")
role := createTestRole(t, db, "User")

// Test CardGroup - Card relationship
var fetchedCardGroup model.CardGroup
// Test Cardgroup - Card relationship
var fetchedCardGroup model.Cardgroup
db.Preload("Cards").First(&fetchedCardGroup, cardGroup.ID)
assert.Len(t, fetchedCardGroup.Cards, 2)
assert.Equal(t, card1.ID, fetchedCardGroup.Cards[0].ID)
assert.Equal(t, card2.ID, fetchedCardGroup.Cards[1].ID)

// Test User - CardGroup relationship
// Test User - Cardgroup relationship
db.Model(&user).Association("CardGroups").Append(&cardGroup)
var fetchedUser model.User
db.Preload("CardGroups").First(&fetchedUser, "id = ?", user.ID)
Expand Down
40 changes: 20 additions & 20 deletions backend/pkg/model/model.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,36 +5,36 @@ import (
)

type User struct {
ID int64 `gorm:"primaryKey"`
Name string `gorm:"not null"`
Created time.Time `gorm:"autoCreateTime"`
Updated time.Time `gorm:"autoUpdateTime"`
CardGroups []CardGroup `gorm:"many2many:cardgroup_users"`
ID int64 `gorm:"column:id;primaryKey"`
Name string `gorm:"column:name;not null"`
Created time.Time `gorm:"column:created;autoCreateTime"`
Updated time.Time `gorm:"column:updated;autoUpdateTime"`
CardGroups []Cardgroup `gorm:"many2many:cardgroup_users"`
Roles []Role `gorm:"many2many:user_roles"`
}

type Card struct {
ID int64 `gorm:"primaryKey"`
Front string `gorm:"not null"`
Back string `gorm:"not null"`
ReviewDate time.Time `gorm:"not null"`
IntervalDays int `gorm:"default:1;not null"`
Created time.Time `gorm:"autoCreateTime"`
Updated time.Time `gorm:"autoUpdateTime"`
CardGroupID int64 `gorm:"foreignKey:cardgroup_id"`
ID int64 `gorm:"column:id;primaryKey"`
Front string `gorm:"column:front;not null"`
Back string `gorm:"column:back;not null"`
ReviewDate time.Time `gorm:"column:review_date;not null"`
IntervalDays int `gorm:"column:interval_days;default:1;not null"`
Created time.Time `gorm:"column:created;autoCreateTime"`
Updated time.Time `gorm:"column:updated;autoUpdateTime"`
CardGroupID int64 `gorm:"column:cardgroup_id;foreignKey:cardgroup_id"`
}

type CardGroup struct {
ID int64 `gorm:"primaryKey"`
Name string `gorm:"not null"`
Created time.Time `gorm:"autoCreateTime"`
Updated time.Time `gorm:"autoUpdateTime"`
type Cardgroup struct {
ID int64 `gorm:"column:id;primaryKey"`
Name string `gorm:"column:name;not null"`
Created time.Time `gorm:"column:created;autoCreateTime"`
Updated time.Time `gorm:"column:updated;autoUpdateTime"`
Cards []Card `gorm:"foreignKey:cardgroup_id"`
Users []User `gorm:"many2many:cardgroup_users"`
}

type Role struct {
ID int64 `gorm:"primaryKey"`
Name string `gorm:"not null"`
ID int64 `gorm:"column:id;primaryKey"`
Name string `gorm:"column:name;not null"`
Users []User `gorm:"many2many:user_roles"`
}

0 comments on commit 96de1ee

Please sign in to comment.