update_users_test.go 1.4 KB
package users

import (
	"net/http"

	"github.com/gavv/httpexpect"
	"github.com/go-pg/pg/v10"
	. "github.com/onsi/ginkgo"
	. "github.com/onsi/gomega"
	pG "github.com/tiptok/godevp/pkg/infrastructure/pg"
)

var _ = Describe("更新", func() {
	var usersId int64
	BeforeEach(func() {
		_, err := pG.DB.QueryOne(
			pg.Scan(&usersId),
			"INSERT INTO users (id, name, phone, passwd, roles, status, admin_type, create_time, update_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?) RETURNING id",
			"testId", "testName", "testPhone", "testPasswd", "testRoles", "testStatus", "testAdminType", "testCreateTime", "testUpdateTime")
		Expect(err).NotTo(HaveOccurred())
	})
	Describe("提交数据更新", func() {
		Context("提交正确的用户实体数据", func() {
			It("返回更新后的用户实体数据", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"usersId": "int64",
				}
				httpExpect.PUT("/users/{Id}").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 0).
					ContainsKey("msg").ValueEqual("msg", "ok").
					ContainsKey("data").Value("data").Object().
					ContainsKey("id").ValueEqual("id", usersId)
			})
		})
	})
	AfterEach(func() {
		_, err := pG.DB.Exec("DELETE FROM users WHERE true")
		Expect(err).NotTo(HaveOccurred())
	})
})