list_company_test.go 1.3 KB
package company

import (
	"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() {
	var companyId int64
	BeforeEach(func() {
		_, err := pG.DB.QueryOne(
			pg.Scan(&companyId),
			"INSERT INTO companys (company_id, company_info, create_at, update_at, delete_at) VALUES (?, ?, ?, ?, ?) RETURNING company_id",
			"testCompanyId", "testCompanyInfo", "testCreateAt", "testUpdateAt", "testDeleteAt")
		Expect(err).NotTo(HaveOccurred())
	})
	Describe("根据参数返回公司信息列表", func() {
		Context("传入有效的参数", func() {
			It("返回公司信息数据列表", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				httpExpect.GET("/companys/").
					WithQuery("offset", "int").
					WithQuery("limit", "int").
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 0).
					ContainsKey("msg").ValueEqual("msg", "ok").
					ContainsKey("data").Value("data").Object().
					ContainsKey("count").ValueEqual("count", 1).
					ContainsKey("companys").Value("companys").Array()
			})
		})
	})
	AfterEach(func() {
		_, err := pG.DB.Exec("DELETE FROM companys WHERE true")
		Expect(err).NotTo(HaveOccurred())
	})
})