release_task_test.go 10.0 KB
package task

import (
	"github.com/gavv/httpexpect"
	"github.com/go-pg/pg"
	. "github.com/onsi/ginkgo"
	. "github.com/onsi/gomega"
	"gitlab.fjmaimaimai.com/linmadan/mmm-worth/pkg/domain"
	pG "gitlab.fjmaimaimai.com/linmadan/mmm-worth/pkg/infrastructure/pg"
	"net/http"
	"time"
)

var _ = Describe("发布任务", func() {
	Describe("发布任务", func() {
		Context("任务发起者发布待发布的任务", func() {
			BeforeEach(func() {
				dayAfter, _ := time.ParseDuration("72h")
				_, err := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO tasks (id, company_id, task_name, task_type, sponsor, task_status, reference_resource, project_belong, customer_values, task_nature, su_money, acceptance_standard, task_description, task_picture_urls, is_reward_take, participators, task_percentage, solve_report, solve_picture_urls, receiver_uid, create_time, release_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
					1, 101, "抢单任务1", 1, &domain.EmployeeInfo{
						Uid: 2499036607974745088,
					}, 1, &domain.ReferenceResource{
						ReferenceResourceType: 1,
						ReferenceResourceItems: []*domain.ReferenceResourceItem{
							{
								ReferenceResourceId: 4,
							},
						},
					}, 1, pg.Array([]int{1, 2, 3, 4}), 1, 1000.00, "验收标准1", "任务描述1", pg.Array([]string{}), true, []*domain.EmployeeInfo{
						{
							Uid: 2499036607974745077,
						},
						{
							Uid: 2499036607974745066,
						},
					}, "null", "", pg.Array([]string{}), 2499036607974745099, time.Now(), time.Now().Add(dayAfter))
				Expect(err).NotTo(HaveOccurred())
				_, err1 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO employees (id, company_id, uid, employee_name, employee_account, su_money) VALUES (?, ?, ?, ?, ?, ?)",
					1, 101, 2499036607974745088, "testEmployeeName", "testEmployeeAccount", 0)
				Expect(err1).NotTo(HaveOccurred())
			})
			It("发布任务成功", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"operator": 2499036607974745088,
				}
				httpExpect.POST("/tasks/1/release").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 0).
					ContainsKey("msg").ValueEqual("msg", "ok").
					ContainsKey("data").Value("data").Object().
					ContainsKey("taskStatus").ValueEqual("taskStatus", 2)
			})
		})
		Context("任务发起者发布不是待发布的任务", func() {
			BeforeEach(func() {
				dayAfter, _ := time.ParseDuration("72h")
				_, err := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO tasks (id, company_id, task_name, task_type, sponsor, task_status, reference_resource, project_belong, customer_values, task_nature, su_money, acceptance_standard, task_description, task_picture_urls, is_reward_take, participators, task_percentage, solve_report, solve_picture_urls, receiver_uid, create_time, release_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
					1, 101, "抢单任务1", 1, &domain.EmployeeInfo{
						Uid: 2499036607974745088,
					}, 3, "null", 1, pg.Array([]int{1, 2, 3, 4}), 1, 1000.00, "验收标准1", "任务描述1", pg.Array([]string{}), true, []*domain.EmployeeInfo{
						{
							Uid: 2499036607974745077,
						},
						{
							Uid: 2499036607974745066,
						},
					}, "null", "", pg.Array([]string{}), 2499036607974745099, time.Now(), time.Now().Add(dayAfter))
				Expect(err).NotTo(HaveOccurred())
				_, err1 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO employees (id, uid, employee_name, employee_account, su_money) VALUES (?, ?, ?, ?, ?)",
					1, 2499036607974745088, "testEmployeeName", "testEmployeeAccount", 0)
				Expect(err1).NotTo(HaveOccurred())
			})
			It("发布任务失败", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"operator": 2499036607974745088,
				}
				httpExpect.POST("/tasks/1/release").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 501).
					ContainsKey("msg").ValueEqual("msg", "内部服务出错:进行中的任务不允许重新发布")
			})
		})
		Context("发布资源已经被引用的的任务", func() {
			BeforeEach(func() {
				dayAfter, _ := time.ParseDuration("72h")
				_, err := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO tasks (id, company_id, task_name, task_type, sponsor, task_status, reference_resource, project_belong, customer_values, task_nature, su_money, acceptance_standard, task_description, task_picture_urls, is_reward_take, participators, task_percentage, solve_report, solve_picture_urls, receiver_uid, create_time, release_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
					1, 101, "抢单任务1", 1, &domain.EmployeeInfo{
						Uid: 2499036607974745088,
					}, 2, &domain.ReferenceResource{
						ReferenceResourceType: 1,
						ReferenceResourceItems: []*domain.ReferenceResourceItem{
							{
								ReferenceResourceId: 4,
							},
						},
					}, 1, pg.Array([]int{1, 2, 3, 4}), 1, 1000.00, "验收标准1", "任务描述1", pg.Array([]string{}), true, []*domain.EmployeeInfo{
						{
							Uid: 2499036607974745077,
						},
						{
							Uid: 2499036607974745066,
						},
					}, "null", "", pg.Array([]string{}), 2499036607974745099, time.Now(), time.Now().Add(dayAfter))
				Expect(err).NotTo(HaveOccurred())
				_, err1 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO employees (id, uid, employee_name, employee_account, su_money) VALUES (?, ?, ?, ?, ?)",
					1, 2499036607974745088, "testEmployeeName", "testEmployeeAccount", 0)
				Expect(err1).NotTo(HaveOccurred())
				_, err2 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO tasks (id, company_id, task_name, task_type, sponsor, task_status, reference_resource, project_belong, customer_values, task_nature, su_money, acceptance_standard, task_description, task_picture_urls, is_reward_take, participators, task_percentage, solve_report, solve_picture_urls, receiver_uid, create_time, release_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
					2, 101, "抢单任务1", 1, &domain.EmployeeInfo{
						Uid: 2499036607974745088,
					}, 2, &domain.ReferenceResource{
						ReferenceResourceType: 1,
						ReferenceResourceItems: []*domain.ReferenceResourceItem{
							{
								ReferenceResourceId: 4,
							},
						},
					}, 1, pg.Array([]int{1, 2, 3, 4}), 1, 1000.00, "验收标准1", "任务描述1", pg.Array([]string{}), true, []*domain.EmployeeInfo{
						{
							Uid: 2499036607974745077,
						},
						{
							Uid: 2499036607974745066,
						},
					}, "null", "", pg.Array([]string{}), 2499036607974745099, time.Now(), time.Now().Add(dayAfter))
				Expect(err2).NotTo(HaveOccurred())
			})
			It("发布任务失败", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"operator": 2499036607974745088,
				}
				httpExpect.POST("/tasks/1/release").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 501).
					ContainsKey("msg").ValueEqual("msg", "内部服务出错:问题资源已经被引用,发布任务失败")
			})
		})
		Context("任务发起者发布待发布的指派任务", func() {
			BeforeEach(func() {
				dayAfter, _ := time.ParseDuration("72h")
				_, err := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO tasks (id, company_id, task_name, task_type, sponsor, task_status, reference_resource, project_belong, customer_values, task_nature, su_money, acceptance_standard, task_description, task_picture_urls, is_reward_take, participators, task_percentage, solve_report, solve_picture_urls, receiver_uid, create_time, release_time, assigned_person, planned_completion_time) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",
					1, 101, "抢单任务1", 3, &domain.EmployeeInfo{
						Uid: 2499036607974745088,
					}, 1, &domain.ReferenceResource{
						ReferenceResourceType: 1,
						ReferenceResourceItems: []*domain.ReferenceResourceItem{
							{
								ReferenceResourceId: 4,
							},
						},
					}, 1, pg.Array([]int{1, 2, 3, 4}), 1, 1000.00, "验收标准1", "任务描述1", pg.Array([]string{}), true, []*domain.EmployeeInfo{
						{
							Uid: 2499036607974745077,
						},
						{
							Uid: 2499036607974745066,
						},
					}, "null", "", pg.Array([]string{}), 2499036607974745099, time.Now(), time.Now().Add(dayAfter), &domain.EmployeeInfo{
						Uid: 2499036607974745099,
					}, time.Now())
				Expect(err).NotTo(HaveOccurred())
				_, err1 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO employees (id, company_id, uid, employee_name, employee_account, su_money) VALUES (?, ?, ?, ?, ?, ?)",
					1, 101, 2499036607974745088, "testEmployeeName", "testEmployeeAccount", 0)
				Expect(err1).NotTo(HaveOccurred())
				_, err2 := pG.DB.QueryOne(
					pg.Scan(),
					"INSERT INTO employees (id, company_id, uid, employee_name, employee_account, su_money) VALUES (?, ?, ?, ?, ?, ?)",
					2, 101, 2499036607974745099, "testEmployeeName", "testEmployeeAccount", 0)
				Expect(err2).NotTo(HaveOccurred())
			})
			It("发布任务成功", func() {
				httpExpect := httpexpect.New(GinkgoT(), server.URL)
				body := map[string]interface{}{
					"operator": 2499036607974745088,
				}
				httpExpect.POST("/tasks/1/release").
					WithJSON(body).
					Expect().
					Status(http.StatusOK).
					JSON().
					Object().
					ContainsKey("code").ValueEqual("code", 0).
					ContainsKey("msg").ValueEqual("msg", "ok").
					ContainsKey("data").Value("data").Object().
					ContainsKey("taskStatus").ValueEqual("taskStatus", 3)
			})
		})
	})
	AfterEach(func() {
		_, err := pG.DB.Exec("DELETE FROM tasks WHERE true")
		Expect(err).NotTo(HaveOccurred())
		_, err1 := pG.DB.Exec("DELETE FROM bid_infos WHERE true")
		Expect(err1).NotTo(HaveOccurred())
		_, err2 := pG.DB.Exec("DELETE FROM bidder_infos WHERE true")
		Expect(err2).NotTo(HaveOccurred())
		_, err3 := pG.DB.Exec("DELETE FROM employees WHERE true")
		Expect(err3).NotTo(HaveOccurred())
	})
})