update_user_test.go 2.3 KB
package user

import (
	"github.com/go-pg/pg/v10"
	"net/http"

	"github.com/gavv/httpexpect"
	. "github.com/onsi/ginkgo"
	. "github.com/onsi/gomega"
	pG "gitlab.fjmaimaimai.com/mmm-go-pp/partner01/pkg/infrastructure/pg"
)

var _ = Describe("更新", func() {
	return
	var userId int64
	BeforeEach(func() {
		_, err := pG.DB.QueryOne(
			pg.Scan(&userId),
			"INSERT INTO users (user_id, user_type, permissions, company_id, user_info, partner_info, status, admin_type, access_partners, create_at, update_at, delete_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) RETURNING user_id",
			"testUserId", "testUserType", "testPermissions", "testCompanyId", "testUserInfo", "testPartnerInfo", "testStatus", "testAdminType", "testAccessPartners", "testCreateAt", "testUpdateAt", "testDeleteAt")
		Expect(err).NotTo(HaveOccurred())
	})
	Describe("提交数据更新", func() {
		Context("提交正确的用户实体数据", func() {
			It("返回更新后的用户实体数据", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"userType":         "int",
					"adminType":        "int",
					"status":           "int64",
					"isPrincipal":      "boolean",
					"uid":              "int64",
					"userAccount":      "string",
					"userAvatarUrl":    "string",
					"userName":         "string",
					"email":            "string",
					"gender":           "int",
					"entryTime":        "datetime",
					"extension":        "string",
					"workplace":        "string",
					"privateNumber":    "string",
					"jobNumber":        "string",
					"partnerAccount":   "string",
					"partnerName":      "string",
					"regionName":       "string",
					"cooperateTime":    "datetime",
					"salesmans":        "array",
					"partnerCategorys": "array",
					"accessPartners":   "array",
				}
				httpExpect.PUT("/users/{userId}").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 0).
					ContainsKey("msg").ValueEqual("msg", "ok").
					ContainsKey("data").Value("data").Object().
					ContainsKey("userId").ValueEqual("userId", userId)
			})
		})
	})
	AfterEach(func() {
		//_, err := pG.DB.Exec("DELETE FROM users WHERE true")
		//Expect(err).NotTo(HaveOccurred())
	})
})