diff --git a/.github/workflows/test-integration.yml b/.github/workflows/test-integration.yml
index 3a24e1f..68ab1ec 100644
--- a/.github/workflows/test-integration.yml
+++ b/.github/workflows/test-integration.yml
@@ -1,4 +1,4 @@
-name: Test Integration
+name: Test (Integration)
on: push
jobs:
diff --git a/.github/workflows/test-unit.yml b/.github/workflows/test-unit.yml
index 94684a6..955c928 100644
--- a/.github/workflows/test-unit.yml
+++ b/.github/workflows/test-unit.yml
@@ -1,4 +1,4 @@
-name: Test Unit
+name: Test (unit)
on: push
jobs:
@@ -8,3 +8,10 @@ jobs:
- uses: actions/checkout@v3
- name: Test Unit
run: make test-unit
+ - name: Coverage report
+ uses: ncruces/go-coverage-report@v0.2.9
+ with:
+ badge-title: Coverage (unit)
+ coverage-file: assets/coverage/unit/coverage.out
+ report: true
+ output-dir: assets/coverage/unit
diff --git a/Makefile b/Makefile
index a8e5717..78adb81 100644
--- a/Makefile
+++ b/Makefile
@@ -28,5 +28,7 @@ lint-golangci: vendor-install
lint-architecture:
docker run --rm -v $(shell pwd):/app -w /app golang:1.20.0 /bin/bash \
-c "go install github.com/fdaines/arch-go@v1.4.2 && arch-go -v"
+generate-go:
+ docker run --rm -v $(shell pwd):/app -w /app golang:1.20.0 /bin/bash -c 'go install go.uber.org/mock/mockgen@v0.3.0 && go generate ./...'
vendor-install:
@if [ -d "vendor" ]; then echo "Vendor folder already exists. Skip vendor installing."; else docker run --rm -v $(shell pwd):/app -w /app golang:1.20.0 /bin/bash -c "go mod tidy && go mod vendor"; fi
\ No newline at end of file
diff --git a/README.md b/README.md
index d536447..12b980d 100644
--- a/README.md
+++ b/README.md
@@ -1,10 +1,13 @@
-[![Lint Golangci][lint-golangci-badge]][lint-golangci-url]
-[![Lint Architecture][lint-architecture-badge]][lint-architecture-url]
-[![Test Unit][test-unit-badge]][test-unit-url]
-[![Test Integration][test-integration-badge]][test-integration-url]
+[![Lint Golangci](https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-golangci.yml/badge.svg)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-golangci.yml)
+[![Lint Architecture](https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-architecture.yml/badge.svg)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-architecture.yml)
+[![Test (unit)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-unit.yml/badge.svg)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-unit.yml)
+[![Coverage (unit)](https://github.com/mgerasimchuk/space-trouble/wiki/assets/coverage/unit/coverage.svg)](https://raw.githack.com/wiki/mgerasimchuk/space-trouble/assets/coverage/unit/coverage.html)
+[![Test (integration)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-integration.yml/badge.svg)](https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-integration.yml)
# Space Trouble
+Solution for the [Space trouble challenge](#space-trouble-challenge)
+
## Requirements
* [Docker Engine](https://docs.docker.com/engine/) (tested on 20.10.7)
@@ -55,39 +58,6 @@ See data in DB:
docker-compose -f deployments/docker-compose/docker-compose.yaml run migrations-up bash -c 'psql -c "SELECT * FROM bookings"'
```
-## Tests
-
-### Unit
-
-Run tests with generating html coverage report:
-
-```
-make test-unit
-```
-
-After executing, you can open generated [assets/coverage/coverage.html](https://htmlpreview.github.io/?https://raw.githubusercontent.com/mgerasimchuk/space-trouble/master/assets/coverage/coverage.html)
-file in browser for checking coverage
-
-### Integration
-
-```
-make test-integration
-```
-
-## Linters
-
-### Golangci
-
-```
-make lint-golangci
-```
-
-### Architecture
-
-```
-make lint-architecture
-```
-
## Configuration
See env file: [deployments/docker-compose/.env](deployments/docker-compose/.env)
@@ -97,9 +67,10 @@ See env file: [deployments/docker-compose/.env](deployments/docker-compose/.env)
As an architectural approach was used
- [The Clean Architecture](https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html)
-The project layout follows [https://github.com/golang-standards/project-layout](https://github.com/golang-standards/project-layout)
+The project layout follows
+- [https://github.com/golang-standards/project-layout](https://github.com/golang-standards/project-layout)
-## Original Technical Task Description
+## Space trouble challenge
Imagine it’s 2049 and you are working for a company called SpaceTrouble that sends people to different places in our
solar system. You are not the only one working in this industry. Your biggest competitor is a less known company called
@@ -144,12 +115,3 @@ Technical requirements:
* Please, use github or bitbucket.
* Commit your changes often. Do not push the whole project in one commit.
-
-[lint-golangci-badge]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-golangci.yml/badge.svg
-[lint-golangci-url]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-golangci.yml
-[lint-architecture-badge]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-architecture.yml/badge.svg
-[lint-architecture-url]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/lint-architecture.yml
-[test-unit-badge]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-unit.yml/badge.svg
-[test-unit-url]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-unit.yml
-[test-integration-badge]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-integration.yml/badge.svg
-[test-integration-url]: https://github.com/mgerasimchuk/space-trouble/actions/workflows/test-integration.yml
diff --git a/assets/coverage/coverage.html b/assets/coverage/coverage.html
deleted file mode 100644
index 65faa54..0000000
--- a/assets/coverage/coverage.html
+++ /dev/null
@@ -1,506 +0,0 @@
-
-
-
-
-
-
-
package entity
-
-import (
- "errors"
- "time"
-)
-
-const (
- StatusCreated = "created"
- StatusPending = "pending"
- StatusDeclined = "declined"
- StatusApproved = "approved"
-)
-
-type Booking struct {
- id string
- status string
- statusReason string
- firstName string
- lastName string
- gender string
- birthday time.Time
- launchpadID string
- destinationID string
- launchDate time.Time
-}
-
-func CreateBooking(firstName, lastName, gender string, birthday time.Time, launchpadID, destinationID string, launchDate time.Time) *Booking {
- b := &Booking{
- firstName: firstName, lastName: lastName, gender: gender, birthday: birthday,
- launchpadID: launchpadID, destinationID: destinationID, launchDate: launchDate,
- }
- b.status = StatusCreated
-
- return b
-}
-
-func LoadBooking(id, status, statusReason, firstName, lastName, gender string, birthday time.Time, launchpadID, destinationID string, launchDate time.Time) *Booking {
- b := &Booking{
- id: id, status: status, statusReason: statusReason, firstName: firstName, lastName: lastName, gender: gender,
- birthday: birthday, launchpadID: launchpadID, destinationID: destinationID, launchDate: launchDate,
- }
-
- return b
-}
-
-func (b *Booking) ID() string {
- return b.id
-}
-
-func (b *Booking) SetID(id string) {
- b.id = id
-}
-
-func (b *Booking) Status() string {
- return b.status
-}
-
-func (b *Booking) SetStatus(status string) {
- b.status = status
-}
-
-func (b *Booking) StatusReason() string {
- return b.statusReason
-}
-
-func (b *Booking) SetStatusReason(statusReason string) {
- b.statusReason = statusReason
-}
-
-func (b *Booking) FirstName() string {
- return b.firstName
-}
-
-func (b *Booking) SetFirstName(firstName string) {
- b.firstName = firstName
-}
-
-func (b *Booking) LastName() string {
- return b.lastName
-}
-
-func (b *Booking) SetLastName(lastName string) {
- b.lastName = lastName
-}
-
-func (b *Booking) Gender() string {
- return b.gender
-}
-
-func (b *Booking) SetGender(gender string) {
- b.gender = gender
-}
-
-func (b *Booking) Birthday() time.Time {
- return b.birthday
-}
-
-func (b *Booking) SetBirthday(birthday time.Time) {
- b.birthday = birthday
-}
-
-func (b *Booking) LaunchpadID() string {
- return b.launchpadID
-}
-
-func (b *Booking) SetLaunchpadID(launchpadID string) {
- b.launchpadID = launchpadID
-}
-
-func (b *Booking) DestinationID() string {
- return b.destinationID
-}
-
-func (b *Booking) SetDestinationID(destinationID string) {
- b.destinationID = destinationID
-}
-
-func (b *Booking) LaunchDate() time.Time {
- return b.launchDate
-}
-
-func (b *Booking) SetLaunchDate(launchDate time.Time) {
- b.launchDate = launchDate
-}
-
-func (b Booking) Validate() error {
- if err := b.validateStatus(); err != nil {
- return err
- }
- if err := b.validateFirstName(); err != nil {
- return err
- }
- if err := b.validateLastName(); err != nil {
- return err
- }
- if err := b.validateGender(); err != nil {
- return err
- }
- if err := b.validateBirthday(); err != nil {
- return err
- }
- if err := b.validateLaunchpadID(); err != nil {
- return err
- }
- if err := b.validateDestinationID(); err != nil {
- return err
- }
- if err := b.validateLaunchDate(); err != nil {
- return err
- }
-
- return nil
-}
-
-func (b Booking) validateStatus() error {
- if b.Status() == "" {
- return errors.New("value of \"status\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateFirstName() error {
- if b.FirstName() == "" {
- return errors.New("value of \"firstName\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateLastName() error {
- if b.LastName() == "" {
- return errors.New("value of \"lastName\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateGender() error {
- if b.Gender() == "" {
- return errors.New("value of \"gender\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateBirthday() error {
- if b.Birthday().After(time.Now()) {
- // actually should be more than at least 18 years
- return errors.New("value of \"birthday\" field should be in the past")
- }
-
- return nil
-}
-
-func (b Booking) validateLaunchpadID() error {
- if b.LaunchpadID() == "" {
- return errors.New("value of \"launchpadID\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateDestinationID() error {
- if b.DestinationID() == "" {
- return errors.New("value of \"destinationID\" field can't be empty")
- }
-
- return nil
-}
-
-func (b Booking) validateLaunchDate() error {
- if b.LaunchDate().Before(time.Now()) {
- return errors.New("value of \"launchDate\" field should be in the future")
- }
-
- return nil
-}
-
-
-
package service
-
-import (
- "github.com/mgerasimchuk/space-trouble/internal/entity"
- "github.com/mgerasimchuk/space-trouble/internal/entity/service/dto"
- "github.com/pkg/errors"
-)
-
-type BookingVerifierService struct {
-}
-
-func NewBookingVerifierService() *BookingVerifierService {
- return &BookingVerifierService{}
-}
-
-func (s BookingVerifierService) Verify(b *entity.Booking, dto dto.BookingVerifyDTO) error {
- if !dto.IsLaunchpadExists {
- b.SetStatus(entity.StatusDeclined)
- err := errors.New("launchpad doesn't exists")
- b.SetStatusReason(err.Error())
- return err
- }
- if !dto.IsLaunchpadActive {
- b.SetStatus(entity.StatusDeclined)
- err := errors.New("launchpad is not active")
- b.SetStatusReason(err.Error())
- return err
- }
- if !dto.IsDateAvailableForLaunch {
- b.SetStatus(entity.StatusDeclined)
- err := errors.New("booking date is not available")
- b.SetStatusReason(err.Error())
- return err
- }
- if !dto.IsLandpadExists {
- b.SetStatus(entity.StatusDeclined)
- err := errors.New("landpad doesn't exists")
- b.SetStatusReason(err.Error())
- return err
- }
- if !dto.IsLandpadActive {
- b.SetStatus(entity.StatusDeclined)
- err := errors.New("landpad is not active")
- b.SetStatusReason(err.Error())
- return err
- }
-
- b.SetStatus(entity.StatusApproved)
- b.SetStatusReason("")
- return nil
-}
-
-
-
package usecase
-
-import (
- "errors"
- "github.com/mgerasimchuk/space-trouble/internal/entity"
- "github.com/mgerasimchuk/space-trouble/internal/entity/service"
- "github.com/mgerasimchuk/space-trouble/internal/entity/service/dto"
- "github.com/mgerasimchuk/space-trouble/internal/usecase/repository"
- "golang.org/x/sync/errgroup"
- "time"
-)
-
-type BookingUsecase struct {
- bookingVerifierSvc *service.BookingVerifierService
- bookingRepo repository.BookingRepository
- launchpadRepo repository.LaunchpadRepository
- landpadRepo repository.LandpadRepository
-}
-
-func NewBookingUsecase(bookingSvc *service.BookingVerifierService, bookingRepo repository.BookingRepository, launchpadRepo repository.LaunchpadRepository, landpadRepo repository.LandpadRepository) *BookingUsecase {
- return &BookingUsecase{bookingVerifierSvc: bookingSvc, bookingRepo: bookingRepo, launchpadRepo: launchpadRepo, landpadRepo: landpadRepo}
-}
-
-var internalError = errors.New("internal error")
-
-func (u *BookingUsecase) CreateBooking(
- firstName string, lastName string, gender string, birthday time.Time,
- launchpadID string, destinationID string, launchDate time.Time,
-) (*entity.Booking, error) {
- b := entity.CreateBooking(firstName, lastName, gender, birthday, launchpadID, destinationID, launchDate)
- if err := b.Validate(); err != nil {
- return nil, err
- }
-
- b, err := u.bookingRepo.Create(b)
- if err != nil {
- return nil, internalError
- }
-
- return b, nil
-}
-
-func (u *BookingUsecase) GetBookings(limit, offset *int) ([]*entity.Booking, error) {
- if limit != nil && *limit < 1 {
- return nil, errors.New("\"limit\" param should be greater than 1")
- }
- if offset != nil && *offset < 0 {
- return nil, errors.New("\"offset\" param should be greater or equal 0")
- }
-
- bookings, err := u.bookingRepo.GetList(nil, limit, offset)
- if err != nil {
- return nil, internalError
- }
-
- return bookings, nil
-}
-
-func (u *BookingUsecase) DeleteBooking(id string) error {
- if id == "" {
- return errors.New("\"id\" can't be empty")
- }
-
- err := u.bookingRepo.Delete(id)
- if err != nil {
- return internalError
- }
-
- return nil
-}
-
-func (u *BookingUsecase) VerifyFirstAvailableBooking() error {
- b, err := u.bookingRepo.GetAndModify(entity.StatusCreated, entity.StatusPending)
- if err != nil {
- return err
- }
- if b == nil {
- return nil
- }
-
- bookingVerifyDTO := dto.BookingVerifyDTO{}
- g := errgroup.Group{}
- g.Go(func() (err error) {
- bookingVerifyDTO.IsLaunchpadExists, err = u.launchpadRepo.IsExists(b.LaunchpadID())
- return err
- })
- g.Go(func() (err error) {
- bookingVerifyDTO.IsLaunchpadActive, err = u.launchpadRepo.IsActive(b.LaunchpadID())
- return err
- })
- g.Go(func() (err error) {
- bookingVerifyDTO.IsDateAvailableForLaunch, err = u.launchpadRepo.IsDateAvailableForLaunch(b.LaunchpadID(), b.LaunchDate())
- return err
- })
- g.Go(func() (err error) {
- bookingVerifyDTO.IsLandpadExists, err = u.landpadRepo.IsExists(b.DestinationID())
- return err
- })
- g.Go(func() (err error) {
- bookingVerifyDTO.IsLandpadActive, err = u.landpadRepo.IsActive(b.DestinationID())
- return err
- })
-
- if err = g.Wait(); err != nil {
- b.SetStatus(entity.StatusDeclined)
- b.SetStatusReason("Unknown reason") // hide errors from the adapters layer
- return err
- }
-
- err = u.bookingVerifierSvc.Verify(b, bookingVerifyDTO)
- if err != nil {
- return err
- }
-
- return u.bookingRepo.Save(b)
-}
-
-
-
-
-
-
diff --git a/assets/coverage/coverage.out b/assets/coverage/coverage.out
deleted file mode 100644
index 61e21e4..0000000
--- a/assets/coverage/coverage.out
+++ /dev/null
@@ -1,113 +0,0 @@
-mode: count
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:28.142,36.2 3 8
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:38.166,45.2 2 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:47.31,49.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:51.36,53.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:55.35,57.2 1 9
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:59.44,61.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:63.41,65.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:67.56,69.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:71.38,73.2 1 8
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:75.50,77.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:79.37,81.2 1 7
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:83.48,85.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:87.35,89.2 1 6
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:91.44,93.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:95.40,97.2 1 5
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:99.51,101.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:103.40,105.2 1 4
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:107.54,109.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:111.42,113.2 1 3
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:115.58,117.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:119.42,121.2 1 2
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:123.55,125.2 1 0
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:127.35,128.43 1 9
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:128.43,130.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:131.2,131.46 1 8
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:131.46,133.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:134.2,134.45 1 7
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:134.45,136.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:137.2,137.43 1 6
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:137.43,139.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:140.2,140.45 1 5
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:140.45,142.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:143.2,143.48 1 4
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:143.48,145.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:146.2,146.50 1 3
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:146.50,148.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:149.2,149.47 1 2
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:149.47,151.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:153.2,153.12 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:156.41,157.22 1 9
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:157.22,159.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:161.2,161.12 1 8
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:164.44,165.25 1 8
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:165.25,167.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:169.2,169.12 1 7
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:172.43,173.24 1 7
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:173.24,175.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:177.2,177.12 1 6
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:180.41,181.22 1 6
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:181.22,183.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:185.2,185.12 1 5
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:188.43,189.36 1 5
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:189.36,192.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:194.2,194.12 1 4
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:197.46,198.27 1 4
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:198.27,200.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:202.2,202.12 1 3
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:205.48,206.29 1 3
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:206.29,208.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:210.2,210.12 1 2
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:213.45,214.39 1 2
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:214.39,216.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/booking.go:218.2,218.12 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:12.58,14.2 1 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:16.91,17.28 1 6
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:17.28,22.3 4 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:23.2,23.28 1 5
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:23.28,28.3 4 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:29.2,29.35 1 4
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:29.35,34.3 4 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:35.2,35.26 1 3
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:35.26,40.3 4 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:41.2,41.26 1 2
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:41.26,46.3 4 1
-github.com/mgerasimchuk/space-trouble/internal/entity/service/booking_verifier.go:48.2,50.12 3 1
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:20.214,22.2 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:29.28,31.37 2 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:31.37,33.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:35.2,36.16 2 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:36.16,38.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:40.2,40.15 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:43.85,44.32 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:44.32,46.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:47.2,47.34 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:47.34,49.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:51.2,52.16 2 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:52.16,54.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:56.2,56.22 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:59.57,60.14 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:60.14,62.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:64.2,65.16 2 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:65.16,67.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:69.2,69.12 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:72.62,74.16 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:74.16,76.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:77.2,77.14 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:77.14,79.3 1 0
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:81.2,83.26 3 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:83.26,86.3 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:87.2,87.26 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:87.26,90.3 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:91.2,91.26 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:91.26,94.3 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:95.2,95.26 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:95.26,98.3 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:99.2,99.26 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:99.26,102.3 2 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:104.2,104.32 1 3
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:104.32,108.3 3 1
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:110.2,111.16 2 2
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:111.16,113.3 1 1
-github.com/mgerasimchuk/space-trouble/internal/usecase/booking.go:115.2,115.30 1 1
diff --git a/assets/coverage/unit/.gitkeep b/assets/coverage/unit/.gitkeep
new file mode 100644
index 0000000..e69de29
diff --git a/go.mod b/go.mod
index 949e3a9..a2e5adb 100644
--- a/go.mod
+++ b/go.mod
@@ -3,54 +3,59 @@ module github.com/mgerasimchuk/space-trouble
go 1.20
require (
- github.com/brianvoe/gofakeit/v6 v6.5.0
- github.com/bxcodec/faker/v3 v3.8.1
github.com/gavv/httpexpect/v2 v2.16.0
- github.com/gin-gonic/gin v1.7.2
- github.com/golang/mock v1.5.0
- github.com/google/uuid v1.3.0
+ github.com/gin-gonic/gin v1.9.1
+ github.com/go-faker/faker/v4 v4.2.0
+ github.com/google/uuid v1.4.0
github.com/jinzhu/gorm v1.9.16
github.com/kelseyhightower/envconfig v1.4.0
- github.com/pkg/errors v0.8.1
- github.com/sirupsen/logrus v1.6.0
- github.com/stretchr/testify v1.7.4
+ github.com/pkg/errors v0.9.1
+ github.com/sirupsen/logrus v1.9.3
+ github.com/stretchr/testify v1.8.4
github.com/toorop/gin-logrus v0.0.0-20210225092905-2c785434f26f
- golang.org/x/sync v0.0.0-20210220032951-036812b2e83c
+ go.uber.org/mock v0.3.0
+ golang.org/x/sync v0.5.0
)
require (
github.com/TylerBrock/colorjson v0.0.0-20200706003622-8a50f05110d2 // indirect
github.com/ajg/form v1.5.1 // indirect
github.com/andybalholm/brotli v1.0.4 // indirect
+ github.com/bytedance/sonic v1.10.2 // indirect
+ github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d // indirect
+ github.com/chenzhuoyu/iasm v0.9.1 // indirect
github.com/davecgh/go-spew v1.1.1 // indirect
github.com/fatih/color v1.15.0 // indirect
github.com/fatih/structs v1.1.0 // indirect
+ github.com/gabriel-vasile/mimetype v1.4.3 // indirect
github.com/gin-contrib/sse v0.1.0 // indirect
- github.com/go-playground/locales v0.13.0 // indirect
- github.com/go-playground/universal-translator v0.17.0 // indirect
- github.com/go-playground/validator/v10 v10.4.1 // indirect
+ github.com/go-playground/locales v0.14.1 // indirect
+ github.com/go-playground/universal-translator v0.18.1 // indirect
+ github.com/go-playground/validator/v10 v10.16.0 // indirect
github.com/gobwas/glob v0.2.3 // indirect
- github.com/golang/protobuf v1.5.2 // indirect
+ github.com/goccy/go-json v0.10.2 // indirect
github.com/google/go-querystring v1.1.0 // indirect
github.com/gorilla/websocket v1.4.2 // indirect
github.com/hpcloud/tail v1.0.0 // indirect
github.com/imkira/go-interpol v1.1.0 // indirect
github.com/jinzhu/inflection v1.0.0 // indirect
- github.com/json-iterator/go v1.1.11 // indirect
+ github.com/json-iterator/go v1.1.12 // indirect
github.com/klauspost/compress v1.15.0 // indirect
- github.com/konsorten/go-windows-terminal-sequences v1.0.3 // indirect
+ github.com/klauspost/cpuid/v2 v2.2.6 // indirect
github.com/kr/pretty v0.1.0 // indirect
- github.com/leodido/go-urn v1.2.0 // indirect
- github.com/lib/pq v1.1.1 // indirect
+ github.com/leodido/go-urn v1.2.4 // indirect
+ github.com/lib/pq v1.10.9 // indirect
github.com/mattn/go-colorable v0.1.13 // indirect
- github.com/mattn/go-isatty v0.0.18 // indirect
+ github.com/mattn/go-isatty v0.0.20 // indirect
github.com/mitchellh/go-wordwrap v1.0.1 // indirect
- github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421 // indirect
- github.com/modern-go/reflect2 v1.0.1 // indirect
+ github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
+ github.com/modern-go/reflect2 v1.0.2 // indirect
+ github.com/pelletier/go-toml/v2 v2.1.0 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
github.com/sanity-io/litter v1.5.5 // indirect
github.com/sergi/go-diff v1.0.0 // indirect
- github.com/ugorji/go/codec v1.1.7 // indirect
+ github.com/twitchyliquid64/golang-asm v0.15.1 // indirect
+ github.com/ugorji/go/codec v1.2.11 // indirect
github.com/valyala/bytebufferpool v1.0.0 // indirect
github.com/valyala/fasthttp v1.34.0 // indirect
github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb // indirect
@@ -59,14 +64,15 @@ require (
github.com/yalp/jsonpath v0.0.0-20180802001716-5cc68e5049a0 // indirect
github.com/yudai/gojsondiff v1.0.0 // indirect
github.com/yudai/golcs v0.0.0-20170316035057-ecda9a501e82 // indirect
- golang.org/x/crypto v0.0.0-20220214200702-86341886e292 // indirect
- golang.org/x/net v0.7.0 // indirect
- golang.org/x/sys v0.7.0 // indirect
- google.golang.org/protobuf v1.26.0 // indirect
+ golang.org/x/arch v0.6.0 // indirect
+ golang.org/x/crypto v0.15.0 // indirect
+ golang.org/x/net v0.18.0 // indirect
+ golang.org/x/sys v0.14.0 // indirect
+ golang.org/x/text v0.14.0 // indirect
+ google.golang.org/protobuf v1.31.0 // indirect
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 // indirect
gopkg.in/fsnotify.v1 v1.4.7 // indirect
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 // indirect
- gopkg.in/yaml.v2 v2.4.0 // indirect
gopkg.in/yaml.v3 v3.0.1 // indirect
moul.io/http2curl/v2 v2.3.0 // indirect
)
diff --git a/go.sum b/go.sum
index 7bb0ffd..dae8c9f 100644
--- a/go.sum
+++ b/go.sum
@@ -6,10 +6,17 @@ github.com/ajg/form v1.5.1/go.mod h1:uL1WgH+h2mgNtvBq0339dVnzXdBETtL2LeUXaIv25UY
github.com/andybalholm/brotli v1.0.4 h1:V7DdXeJtZscaqfNuAdSRuRFzuiKlHSC/Zh3zl9qY3JY=
github.com/andybalholm/brotli v1.0.4/go.mod h1:fO7iG3H7G2nSZ7m0zPUDn85XEX2GTukHGRSepvi9Eig=
github.com/andybalholm/cascadia v1.1.0/go.mod h1:GsXiBklL0woXo1j/WYWtSYYC4ouU9PqHO0sqidkEA4Y=
-github.com/brianvoe/gofakeit/v6 v6.5.0 h1:zoWqGsuB8TB4MSwUZXtV3OwUSdzi8EHeXO8JfReRIHg=
-github.com/brianvoe/gofakeit/v6 v6.5.0/go.mod h1:palrJUk4Fyw38zIFB/uBZqsgzW5VsNllhHKKwAebzew=
-github.com/bxcodec/faker/v3 v3.8.1 h1:qO/Xq19V6uHt2xujwpaetgKhraGCapqY2CRWGD/SqcM=
-github.com/bxcodec/faker/v3 v3.8.1/go.mod h1:DdSDccxF5msjFo5aO4vrobRQ8nIApg8kq3QWPEQD6+o=
+github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM=
+github.com/bytedance/sonic v1.10.0-rc/go.mod h1:ElCzW+ufi8qKqNW0FY314xriJhyJhuoJ3gFZdAHF7NM=
+github.com/bytedance/sonic v1.10.2 h1:GQebETVBxYB7JGWJtLBi07OVzWwt+8dWA00gEVW2ZFE=
+github.com/bytedance/sonic v1.10.2/go.mod h1:iZcSUejdk5aukTND/Eu/ivjQuEL0Cu9/rf50Hi0u/g4=
+github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY=
+github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk=
+github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d h1:77cEq6EriyTZ0g/qfRdp61a3Uu/AWrgIq2s0ClJV1g0=
+github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d/go.mod h1:8EPpVsBuRksnlj1mLy4AWzRNQYxauNi62uWcE3to6eA=
+github.com/chenzhuoyu/iasm v0.9.0/go.mod h1:Xjy2NpN3h7aUqeqM+woSuuvxmIe6+DDsiNLIrkAmYog=
+github.com/chenzhuoyu/iasm v0.9.1 h1:tUHQJXo3NhBqw6s33wkGn9SP3bvrWLdlVIJ3hQBL7P0=
+github.com/chenzhuoyu/iasm v0.9.1/go.mod h1:Xjy2NpN3h7aUqeqM+woSuuvxmIe6+DDsiNLIrkAmYog=
github.com/davecgh/go-spew v0.0.0-20161028175848-04cdfd42973b/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
@@ -22,40 +29,40 @@ github.com/fatih/color v1.15.0 h1:kOqh6YHBtK8aywxGerMG2Eq3H6Qgoqeo13Bk2Mv/nBs=
github.com/fatih/color v1.15.0/go.mod h1:0h5ZqXfHYED7Bhv2ZJamyIOUej9KtShiJESRwBDUSsw=
github.com/fatih/structs v1.1.0 h1:Q7juDM0QtcnhCpeyLGQKyg4TOIghuNXrkL32pHAUMxo=
github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M=
+github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0=
+github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk=
github.com/gavv/httpexpect/v2 v2.16.0 h1:Ty2favARiTYTOkCRZGX7ojXXjGyNAIohM1lZ3vqaEwI=
github.com/gavv/httpexpect/v2 v2.16.0/go.mod h1:uJLaO+hQ25ukBJtQi750PsztObHybNllN+t+MbbW8PY=
github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE=
github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
-github.com/gin-gonic/gin v1.7.2 h1:Tg03T9yM2xa8j6I3Z3oqLaQRSmKvxPd6g/2HJ6zICFA=
-github.com/gin-gonic/gin v1.7.2/go.mod h1:jD2toBW3GZUr5UMcdrwQA10I7RuaFOl/SGeDjXkfUtY=
-github.com/go-playground/assert/v2 v2.0.1 h1:MsBgLAaY856+nPRTKrp3/OZK38U/wa0CcBYNjji3q3A=
-github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
-github.com/go-playground/locales v0.13.0 h1:HyWk6mgj5qFqCT5fjGBuRArbVDfE4hi8+e8ceBS/t7Q=
-github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8=
-github.com/go-playground/universal-translator v0.17.0 h1:icxd5fm+REJzpZx7ZfpaD876Lmtgy7VtROAbHHXk8no=
-github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+Scu5vgOQjsIJAF8j9muTVoKLVtA=
-github.com/go-playground/validator/v10 v10.4.1 h1:pH2c5ADXtd66mxoE0Zm9SUhxE20r7aM3F26W0hOn+GE=
-github.com/go-playground/validator/v10 v10.4.1/go.mod h1:nlOn6nFhuKACm19sB/8EGNn9GlaMV7XkbRSipzJ0Ii4=
+github.com/gin-gonic/gin v1.9.1 h1:4idEAncQnU5cB7BeOkPtxjfCSye0AAm1R0RVIqJ+Jmg=
+github.com/gin-gonic/gin v1.9.1/go.mod h1:hPrL7YrpYKXt5YId3A/Tnip5kqbEAP+KLuI3SUcPTeU=
+github.com/go-faker/faker/v4 v4.2.0 h1:dGebOupKwssrODV51E0zbMrv5e2gO9VWSLNC1WDCpWg=
+github.com/go-faker/faker/v4 v4.2.0/go.mod h1:F/bBy8GH9NxOxMInug5Gx4WYeG6fHJZ8Ol/dhcpRub4=
+github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s=
+github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA=
+github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY=
+github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY=
+github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY=
+github.com/go-playground/validator/v10 v10.16.0 h1:x+plE831WK4vaKHO/jpgUGsvLKIqRRkz6M78GuJAfGE=
+github.com/go-playground/validator/v10 v10.16.0/go.mod h1:9iXMNT7sEkjXb0I+enO7QXmzG6QCsPWY4zveKFVRSyU=
github.com/go-sql-driver/mysql v1.5.0 h1:ozyZYNQW3x3HtqT1jira07DN2PArx2v7/mN66gGcHOs=
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
github.com/gobwas/glob v0.2.3 h1:A4xDbljILXROh+kObIiy5kIaPYD8e96x1tgBhUI5J+Y=
github.com/gobwas/glob v0.2.3/go.mod h1:d3Ez4x06l9bZtSvzIay5+Yzi0fmZzPgnTbPcKjJAkT8=
+github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU=
+github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I=
github.com/golang-sql/civil v0.0.0-20190719163853-cb61b32ac6fe h1:lXe2qZdvpiX5WZkZR4hgp4KJVfY3nMkvmwbVkpv1rVY=
github.com/golang-sql/civil v0.0.0-20190719163853-cb61b32ac6fe/go.mod h1:8vg3r2VgvsThLBIFL93Qb5yWzgyZWhEmBwUJWevAkK0=
-github.com/golang/mock v1.5.0 h1:jlYHihg//f7RRwuPfptm04yp4s7O6Kw8EZiVYIGcH0g=
-github.com/golang/mock v1.5.0/go.mod h1:CWnOUgYIOo4TcNZ0wHX3YZCqsaM1I1Jvs6v3mP3KVu8=
-github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
-github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
-github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU=
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-querystring v1.1.0 h1:AnCroh3fv4ZBgVIf1Iwtovgjaw/GiKJo8M8yD/fhyJ8=
github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17icRSOU623lUBU=
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
-github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I=
-github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
+github.com/google/uuid v1.4.0 h1:MtMxsa51/r9yyhkyLsVeVt0B+BGQZzpQiTQ4eHZ8bc4=
+github.com/google/uuid v1.4.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc=
github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
github.com/hokaccha/go-prettyjson v0.0.0-20211117102719-0474bc63780f h1:7LYC+Yfkj3CTRcShK0KOL/w6iTiKyqqBA9a41Wnggw8=
@@ -69,44 +76,47 @@ github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD
github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc=
github.com/jinzhu/now v1.0.1 h1:HjfetcXq097iXP0uoPCdnM4Efp5/9MsM0/M+XOTeR3M=
github.com/jinzhu/now v1.0.1/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
-github.com/json-iterator/go v1.1.9/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
-github.com/json-iterator/go v1.1.11 h1:uVUAXhF2To8cbw/3xN3pxj6kk7TYKs98NIrTqPlMWAQ=
-github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
+github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
+github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
github.com/kelseyhightower/envconfig v1.4.0 h1:Im6hONhd3pLkfDFsbRgu68RDNkGF1r3dvMUtDTo2cv8=
github.com/kelseyhightower/envconfig v1.4.0/go.mod h1:cccZRl6mQpaq41TPp5QxidR+Sa3axMbJDNb//FQX6Gg=
github.com/klauspost/compress v1.15.0 h1:xqfchp4whNFxn5A4XFyyYtitiWI8Hy5EW59jEwcyL6U=
github.com/klauspost/compress v1.15.0/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
-github.com/konsorten/go-windows-terminal-sequences v1.0.3 h1:CE8S1cTafDpPvMhIxNJKvHsGVBgn1xWYf1NbHQhywc8=
-github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
+github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
+github.com/klauspost/cpuid/v2 v2.2.6 h1:ndNyv040zDGIDh8thGkXYjnFtiN02M1PVVF+JE/48xc=
+github.com/klauspost/cpuid/v2 v2.2.6/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
+github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M=
github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI=
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE=
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
-github.com/leodido/go-urn v1.2.0 h1:hpXL4XnriNwQ/ABnpepYM/1vCLWNDfUNts8dX3xTG6Y=
-github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII=
-github.com/lib/pq v1.1.1 h1:sJZmqHoEaY7f+NPP8pgLB/WxulyR3fewgCM2qaSlBb4=
+github.com/leodido/go-urn v1.2.4 h1:XlAE/cm/ms7TE/VMVoduSpNBoyc2dOxHs5MZSwAN63Q=
+github.com/leodido/go-urn v1.2.4/go.mod h1:7ZrI8mTSeBSHl/UaRyKQW1qZeMgak41ANeCNaVckg+4=
github.com/lib/pq v1.1.1/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo=
+github.com/lib/pq v1.10.9 h1:YXG7RB+JIjhP29X+OtkiDnYaXQwpS4JEWq7dtCCRUEw=
+github.com/lib/pq v1.10.9/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA=
github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg=
-github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM=
-github.com/mattn/go-isatty v0.0.18 h1:DOKFKCQ7FNG2L1rbrmstDN4QVRdS89Nkh85u68Uwp98=
-github.com/mattn/go-isatty v0.0.18/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
+github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY=
+github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
github.com/mattn/go-sqlite3 v1.14.0 h1:mLyGNKR8+Vv9CAU7PphKa2hkEqxxhn8i32J6FPj1/QA=
github.com/mattn/go-sqlite3 v1.14.0/go.mod h1:JIl7NbARA7phWnGvh0LKTyg7S9BA+6gx71ShQilpsus=
github.com/mitchellh/go-wordwrap v1.0.1 h1:TLuKupo69TCn6TQSyGxwI1EblZZEsQ0vMlAFQflz0v0=
github.com/mitchellh/go-wordwrap v1.0.1/go.mod h1:R62XHJLzvMFRBbcrT7m7WgmE1eOyTSsCt+hzestvNj0=
-github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421 h1:ZqeYNhU3OHLH3mGKHDcjJRFFRrJa6eAM5H+CtDdOsPc=
github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
-github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
-github.com/modern-go/reflect2 v1.0.1 h1:9f412s+6RmYXLWZSEzVVgPGK7C2PphHj5RJrvfx9AWI=
-github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
+github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
+github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
+github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
github.com/onsi/ginkgo v1.10.1 h1:q/mM8GF/n0shIN8SaAZ0V+jnLPzen6WIVZdiwrRlMlo=
github.com/onsi/gomega v1.7.0 h1:XPnZz8VVBHjVsy1vzJmRwIcSwiUO+JFfrv/xGiigmME=
+github.com/pelletier/go-toml/v2 v2.1.0 h1:FnwAJ4oYMvbT/34k9zzHuZNrhlz48GB3/s6at6/MHO4=
+github.com/pelletier/go-toml/v2 v2.1.0/go.mod h1:tJU2Z3ZkXwnxa4DPO899bsyIoywizdUvyaeZurnPPDc=
github.com/pkg/diff v0.0.0-20200914180035-5b29258ca4f7/go.mod h1:zO8QMzTeZd5cpnIkz/Gn6iK0jDfGicM1nynOkkPIl28=
-github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I=
-github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
+github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
+github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pmezard/go-difflib v0.0.0-20151028094244-d8ed2627bdf0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
@@ -114,23 +124,28 @@ github.com/sanity-io/litter v1.5.5 h1:iE+sBxPBzoK6uaEP5Lt3fHNgpKcHXc/A2HGETy0uJQ
github.com/sanity-io/litter v1.5.5/go.mod h1:9gzJgR2i4ZpjZHsKvUXIRQVk7P+yM3e+jAF7bU2UI5U=
github.com/sergi/go-diff v1.0.0 h1:Kpca3qRNrduNnOQeazBd0ysaKrUJiIuISHxogkT9RPQ=
github.com/sergi/go-diff v1.0.0/go.mod h1:0CfEIISq7TuYL3j771MWULgwwjU+GofnZX9QAmXWZgo=
-github.com/sirupsen/logrus v1.6.0 h1:UBcNElsrwanuuMsnGSlYmtmgbb23qDR5dG+6X6Oo89I=
-github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
+github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ=
+github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
+github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo=
github.com/stretchr/testify v0.0.0-20161117074351-18a02ba4a312/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
-github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
+github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
-github.com/stretchr/testify v1.7.4 h1:wZRexSlwd7ZXfKINDLsO4r7WBt3gTKONc6K/VesHvHM=
-github.com/stretchr/testify v1.7.4/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
+github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
+github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
+github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
+github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
+github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
github.com/tailscale/depaware v0.0.0-20210622194025-720c4b409502/go.mod h1:p9lPsd+cx33L3H9nNoecRRxPssFKUwwI50I3pZ0yT+8=
github.com/toorop/gin-logrus v0.0.0-20210225092905-2c785434f26f h1:oqdnd6OGlOUu1InG37hWcCB3a+Jy3fwjylyVboaNMwY=
github.com/toorop/gin-logrus v0.0.0-20210225092905-2c785434f26f/go.mod h1:X3Dd1SB8Gt1V968NTzpKFjMM6O8ccta2NPC6MprOxZQ=
-github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw=
-github.com/ugorji/go/codec v1.1.7 h1:2SvQaVZ1ouYrrKKwoSk2pzd4A9evlKJb9oTL+OaLUSs=
-github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY=
+github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI=
+github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08=
+github.com/ugorji/go/codec v1.2.11 h1:BMaWp1Bb6fHwEtbplGBGJ498wD+LKlNSl25MjdZY4dU=
+github.com/ugorji/go/codec v1.2.11/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg=
github.com/valyala/bytebufferpool v1.0.0 h1:GqA5TC/0021Y/b9FG4Oi9Mr3q7XYx6KllzawFIhcdPw=
github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc=
github.com/valyala/fasthttp v1.34.0 h1:d3AAQJ2DRcxJYHm7OXNXtXt2as1vMDfxeIcFvhmGGm4=
@@ -151,13 +166,19 @@ github.com/yudai/golcs v0.0.0-20170316035057-ecda9a501e82 h1:BHyfKlQyqbsFN5p3Ifn
github.com/yudai/golcs v0.0.0-20170316035057-ecda9a501e82/go.mod h1:lgjkn3NuSvDfVJdfcVVdX+jpBxNmX4rDAzaS45IcYoM=
github.com/yudai/pp v2.0.1+incompatible h1:Q4//iY4pNF6yPLZIigmvcl7k/bPgrcTPIFIcmawg5bI=
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
+go.uber.org/mock v0.3.0 h1:3mUxI1No2/60yUYax92Pt8eNOEecx2D3lcXZh2NEZJo=
+go.uber.org/mock v0.3.0/go.mod h1:a6FSlNadKUHUa9IP5Vyt1zh4fC7uAwxMutEAscFbkZc=
+golang.org/x/arch v0.0.0-20210923205945-b76863e36670/go.mod h1:5om86z9Hs0C8fWVUuoMHwpExlXzs5Tkyp9hOrfG7pp8=
+golang.org/x/arch v0.6.0 h1:S0JTfE48HbRj80+4tbvZDYsJ3tGv6BUU3XxyZ7CirAc=
+golang.org/x/arch v0.6.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys=
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.0.0-20190325154230-a5d413f7728c/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20191205180655-e7c4368fe9dd/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
-golang.org/x/crypto v0.0.0-20220214200702-86341886e292 h1:f+lwQ+GtmgoY+A2YaQxlSOnDjXcQ7ZRLWOHbC6HtRqE=
golang.org/x/crypto v0.0.0-20220214200702-86341886e292/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.15.0 h1:frVn1TEaCEaZcn3Tmd7Y2b5KKPaZ+I32Q2OA3kYp5TA=
+golang.org/x/crypto v0.15.0/go.mod h1:4ChreQoLWfG3xLDer1WdlH5NdlQ3+mwnQq1YTKY+72g=
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/net v0.0.0-20180218175443-cbe0f9307d01/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
@@ -168,16 +189,14 @@ golang.org/x/net v0.0.0-20200324143707-d3edc9973b7e/go.mod h1:qpuaurCH72eLCgpAm/
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
-golang.org/x/net v0.7.0 h1:rJrUqqhjsgNp7KqAIc25s9pZnjU7TUcSY7HcVZjdn1g=
-golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
+golang.org/x/net v0.18.0 h1:mIYleuAkSbHh0tCv7RvjL3F6ZVbLjq4+R7zbOn3Kokg=
+golang.org/x/net v0.18.0/go.mod h1:/czyP5RqHAH4odGYxBJ1qz0+CE5WZ+2j1YgoEo8F2jQ=
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
-golang.org/x/sync v0.0.0-20210220032951-036812b2e83c h1:5KslGYwFpkhGh+Q16bwMP3cOontH8FOep7tGV86Y7SQ=
-golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.5.0 h1:60k92dhOjHxJkrqnwsfl8KuaHbn/5dl0lUPUklKo3qE=
+golang.org/x/sync v0.5.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
@@ -185,18 +204,20 @@ golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220227234510-4e6760a101f9/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
-golang.org/x/sys v0.7.0 h1:3jlCCIQZPdOYu1h8BkNvLz8Kgwtae2cagcG/VamtZRU=
-golang.org/x/sys v0.7.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q=
+golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
-golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
-golang.org/x/text v0.7.0 h1:4BRB4x83lYWy72KwLD/qYDuTu7q9PjSagHvijDw7cLo=
+golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ=
+golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
golang.org/x/tools v0.0.0-20201211185031-d93e913c1a58/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
@@ -206,8 +227,8 @@ golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8T
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
-google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk=
-google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
+google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8=
+google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 h1:qIbj1fsPNlZgppZ+VLlY7N33q108Sa+fhmuc+sWQYwY=
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
@@ -216,11 +237,11 @@ gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMy
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ=
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw=
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
-gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
-gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
moul.io/http2curl/v2 v2.3.0 h1:9r3JfDzWPcbIklMOs2TnIFzDYvfAZvjeavG6EzP7jYs=
moul.io/http2curl/v2 v2.3.0/go.mod h1:RW4hyBjTWSYDOxapodpNEtX0g5Eb16sxklBqmd2RHcE=
+nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50=
+rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4=
diff --git a/internal/adapter/repository/mock/booking.go b/internal/adapter/repository/mock/booking.go
index 9f5399f..023ff16 100644
--- a/internal/adapter/repository/mock/booking.go
+++ b/internal/adapter/repository/mock/booking.go
@@ -1,107 +1,112 @@
// Code generated by MockGen. DO NOT EDIT.
-// Source: internal/entity/repository/booking_verifier.go
-
+// Source: booking.go
+//
+// Generated by this command:
+//
+// mockgen -source=booking.go -destination=../../adapter/repository/mock/booking.go -package=mock
+//
// Package mock is a generated GoMock package.
package mock
import (
- gomock "github.com/golang/mock/gomock"
- model "github.com/mgerasimchuk/space-trouble/internal/entity"
reflect "reflect"
+
+ entity "github.com/mgerasimchuk/space-trouble/internal/entity"
+ gomock "go.uber.org/mock/gomock"
)
-// MockBookingRepository is a mock of BookingRepository interface
+// MockBookingRepository is a mock of BookingRepository interface.
type MockBookingRepository struct {
ctrl *gomock.Controller
recorder *MockBookingRepositoryMockRecorder
}
-// MockBookingRepositoryMockRecorder is the mock recorder for MockBookingRepository
+// MockBookingRepositoryMockRecorder is the mock recorder for MockBookingRepository.
type MockBookingRepositoryMockRecorder struct {
mock *MockBookingRepository
}
-// NewMockBookingRepository creates a new mock instance
+// NewMockBookingRepository creates a new mock instance.
func NewMockBookingRepository(ctrl *gomock.Controller) *MockBookingRepository {
mock := &MockBookingRepository{ctrl: ctrl}
mock.recorder = &MockBookingRepositoryMockRecorder{mock}
return mock
}
-// EXPECT returns an object that allows the caller to indicate expected use
+// EXPECT returns an object that allows the caller to indicate expected use.
func (m *MockBookingRepository) EXPECT() *MockBookingRepositoryMockRecorder {
return m.recorder
}
-// Create mocks base method
-func (m *MockBookingRepository) Create(b *model.Booking) (*model.Booking, error) {
+// Create mocks base method.
+func (m *MockBookingRepository) Create(b *entity.Booking) (*entity.Booking, error) {
m.ctrl.T.Helper()
ret := m.ctrl.Call(m, "Create", b)
- ret0, _ := ret[0].(*model.Booking)
+ ret0, _ := ret[0].(*entity.Booking)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// Create indicates an expected call of Create
-func (mr *MockBookingRepositoryMockRecorder) Create(b interface{}) *gomock.Call {
+// Create indicates an expected call of Create.
+func (mr *MockBookingRepositoryMockRecorder) Create(b any) *gomock.Call {
mr.mock.ctrl.T.Helper()
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Create", reflect.TypeOf((*MockBookingRepository)(nil).Create), b)
}
-// Save mocks base method
-func (m *MockBookingRepository) Save(b *model.Booking) error {
+// Delete mocks base method.
+func (m *MockBookingRepository) Delete(id string) error {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "Save", b)
+ ret := m.ctrl.Call(m, "Delete", id)
ret0, _ := ret[0].(error)
return ret0
}
-// Save indicates an expected call of Save
-func (mr *MockBookingRepositoryMockRecorder) Save(b interface{}) *gomock.Call {
+// Delete indicates an expected call of Delete.
+func (mr *MockBookingRepositoryMockRecorder) Delete(id any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Save", reflect.TypeOf((*MockBookingRepository)(nil).Save), b)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Delete", reflect.TypeOf((*MockBookingRepository)(nil).Delete), id)
}
-// GetList mocks base method
-func (m *MockBookingRepository) GetList(status *string, limit, offset *int) ([]*model.Booking, error) {
+// GetAndModify mocks base method.
+func (m *MockBookingRepository) GetAndModify(searchStatus, modifyStatus string) (*entity.Booking, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "GetList", status, limit, offset)
- ret0, _ := ret[0].([]*model.Booking)
+ ret := m.ctrl.Call(m, "GetAndModify", searchStatus, modifyStatus)
+ ret0, _ := ret[0].(*entity.Booking)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// GetList indicates an expected call of GetList
-func (mr *MockBookingRepositoryMockRecorder) GetList(status, limit, offset interface{}) *gomock.Call {
+// GetAndModify indicates an expected call of GetAndModify.
+func (mr *MockBookingRepositoryMockRecorder) GetAndModify(searchStatus, modifyStatus any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetList", reflect.TypeOf((*MockBookingRepository)(nil).GetList), status, limit, offset)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetAndModify", reflect.TypeOf((*MockBookingRepository)(nil).GetAndModify), searchStatus, modifyStatus)
}
-// Delete mocks base method
-func (m *MockBookingRepository) Delete(id string) error {
+// GetList mocks base method.
+func (m *MockBookingRepository) GetList(status *string, limit, offset *int) ([]*entity.Booking, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "Delete", id)
- ret0, _ := ret[0].(error)
- return ret0
+ ret := m.ctrl.Call(m, "GetList", status, limit, offset)
+ ret0, _ := ret[0].([]*entity.Booking)
+ ret1, _ := ret[1].(error)
+ return ret0, ret1
}
-// Delete indicates an expected call of Delete
-func (mr *MockBookingRepositoryMockRecorder) Delete(id interface{}) *gomock.Call {
+// GetList indicates an expected call of GetList.
+func (mr *MockBookingRepositoryMockRecorder) GetList(status, limit, offset any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Delete", reflect.TypeOf((*MockBookingRepository)(nil).Delete), id)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetList", reflect.TypeOf((*MockBookingRepository)(nil).GetList), status, limit, offset)
}
-// GetAndModify mocks base method
-func (m *MockBookingRepository) GetAndModify(searchStatus, modifyStatus string) (*model.Booking, error) {
+// Save mocks base method.
+func (m *MockBookingRepository) Save(b *entity.Booking) error {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "GetAndModify", searchStatus, modifyStatus)
- ret0, _ := ret[0].(*model.Booking)
- ret1, _ := ret[1].(error)
- return ret0, ret1
+ ret := m.ctrl.Call(m, "Save", b)
+ ret0, _ := ret[0].(error)
+ return ret0
}
-// GetAndModify indicates an expected call of GetAndModify
-func (mr *MockBookingRepositoryMockRecorder) GetAndModify(searchStatus, modifyStatus interface{}) *gomock.Call {
+// Save indicates an expected call of Save.
+func (mr *MockBookingRepositoryMockRecorder) Save(b any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetAndModify", reflect.TypeOf((*MockBookingRepository)(nil).GetAndModify), searchStatus, modifyStatus)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Save", reflect.TypeOf((*MockBookingRepository)(nil).Save), b)
}
diff --git a/internal/adapter/repository/mock/landpad.go b/internal/adapter/repository/mock/landpad.go
index 7fe4353..bc6407d 100644
--- a/internal/adapter/repository/mock/landpad.go
+++ b/internal/adapter/repository/mock/landpad.go
@@ -1,63 +1,68 @@
// Code generated by MockGen. DO NOT EDIT.
-// Source: internal/entity/repository/landpad.go
-
+// Source: landpad.go
+//
+// Generated by this command:
+//
+// mockgen -source=landpad.go -destination=../../adapter/repository/mock/landpad.go -package=mock
+//
// Package mock is a generated GoMock package.
package mock
import (
- gomock "github.com/golang/mock/gomock"
reflect "reflect"
+
+ gomock "go.uber.org/mock/gomock"
)
-// MockLandpadRepository is a mock of LandpadRepository interface
+// MockLandpadRepository is a mock of LandpadRepository interface.
type MockLandpadRepository struct {
ctrl *gomock.Controller
recorder *MockLandpadRepositoryMockRecorder
}
-// MockLandpadRepositoryMockRecorder is the mock recorder for MockLandpadRepository
+// MockLandpadRepositoryMockRecorder is the mock recorder for MockLandpadRepository.
type MockLandpadRepositoryMockRecorder struct {
mock *MockLandpadRepository
}
-// NewMockLandpadRepository creates a new mock instance
+// NewMockLandpadRepository creates a new mock instance.
func NewMockLandpadRepository(ctrl *gomock.Controller) *MockLandpadRepository {
mock := &MockLandpadRepository{ctrl: ctrl}
mock.recorder = &MockLandpadRepositoryMockRecorder{mock}
return mock
}
-// EXPECT returns an object that allows the caller to indicate expected use
+// EXPECT returns an object that allows the caller to indicate expected use.
func (m *MockLandpadRepository) EXPECT() *MockLandpadRepositoryMockRecorder {
return m.recorder
}
-// IsExists mocks base method
-func (m *MockLandpadRepository) IsExists(id string) (bool, error) {
+// IsActive mocks base method.
+func (m *MockLandpadRepository) IsActive(id string) (bool, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "IsExists", id)
+ ret := m.ctrl.Call(m, "IsActive", id)
ret0, _ := ret[0].(bool)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// IsExists indicates an expected call of IsExists
-func (mr *MockLandpadRepositoryMockRecorder) IsExists(id interface{}) *gomock.Call {
+// IsActive indicates an expected call of IsActive.
+func (mr *MockLandpadRepositoryMockRecorder) IsActive(id any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsExists", reflect.TypeOf((*MockLandpadRepository)(nil).IsExists), id)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsActive", reflect.TypeOf((*MockLandpadRepository)(nil).IsActive), id)
}
-// IsActive mocks base method
-func (m *MockLandpadRepository) IsActive(id string) (bool, error) {
+// IsExists mocks base method.
+func (m *MockLandpadRepository) IsExists(id string) (bool, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "IsActive", id)
+ ret := m.ctrl.Call(m, "IsExists", id)
ret0, _ := ret[0].(bool)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// IsActive indicates an expected call of IsActive
-func (mr *MockLandpadRepositoryMockRecorder) IsActive(id interface{}) *gomock.Call {
+// IsExists indicates an expected call of IsExists.
+func (mr *MockLandpadRepositoryMockRecorder) IsExists(id any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsActive", reflect.TypeOf((*MockLandpadRepository)(nil).IsActive), id)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsExists", reflect.TypeOf((*MockLandpadRepository)(nil).IsExists), id)
}
diff --git a/internal/adapter/repository/mock/launchpad.go b/internal/adapter/repository/mock/launchpad.go
index 6828064..689cc60 100644
--- a/internal/adapter/repository/mock/launchpad.go
+++ b/internal/adapter/repository/mock/launchpad.go
@@ -1,79 +1,84 @@
// Code generated by MockGen. DO NOT EDIT.
-// Source: internal/entity/repository/launchpad.go
-
+// Source: launchpad.go
+//
+// Generated by this command:
+//
+// mockgen -source=launchpad.go -destination=../../adapter/repository/mock/launchpad.go -package=mock
+//
// Package mock is a generated GoMock package.
package mock
import (
- gomock "github.com/golang/mock/gomock"
reflect "reflect"
time "time"
+
+ gomock "go.uber.org/mock/gomock"
)
-// MockLaunchpadRepository is a mock of LaunchpadRepository interface
+// MockLaunchpadRepository is a mock of LaunchpadRepository interface.
type MockLaunchpadRepository struct {
ctrl *gomock.Controller
recorder *MockLaunchpadRepositoryMockRecorder
}
-// MockLaunchpadRepositoryMockRecorder is the mock recorder for MockLaunchpadRepository
+// MockLaunchpadRepositoryMockRecorder is the mock recorder for MockLaunchpadRepository.
type MockLaunchpadRepositoryMockRecorder struct {
mock *MockLaunchpadRepository
}
-// NewMockLaunchpadRepository creates a new mock instance
+// NewMockLaunchpadRepository creates a new mock instance.
func NewMockLaunchpadRepository(ctrl *gomock.Controller) *MockLaunchpadRepository {
mock := &MockLaunchpadRepository{ctrl: ctrl}
mock.recorder = &MockLaunchpadRepositoryMockRecorder{mock}
return mock
}
-// EXPECT returns an object that allows the caller to indicate expected use
+// EXPECT returns an object that allows the caller to indicate expected use.
func (m *MockLaunchpadRepository) EXPECT() *MockLaunchpadRepositoryMockRecorder {
return m.recorder
}
-// IsExists mocks base method
-func (m *MockLaunchpadRepository) IsExists(id string) (bool, error) {
+// IsActive mocks base method.
+func (m *MockLaunchpadRepository) IsActive(id string) (bool, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "IsExists", id)
+ ret := m.ctrl.Call(m, "IsActive", id)
ret0, _ := ret[0].(bool)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// IsExists indicates an expected call of IsExists
-func (mr *MockLaunchpadRepositoryMockRecorder) IsExists(id interface{}) *gomock.Call {
+// IsActive indicates an expected call of IsActive.
+func (mr *MockLaunchpadRepositoryMockRecorder) IsActive(id any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsExists", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsExists), id)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsActive", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsActive), id)
}
-// IsActive mocks base method
-func (m *MockLaunchpadRepository) IsActive(id string) (bool, error) {
+// IsDateAvailableForLaunch mocks base method.
+func (m *MockLaunchpadRepository) IsDateAvailableForLaunch(launchpadID string, launchDate time.Time) (bool, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "IsActive", id)
+ ret := m.ctrl.Call(m, "IsDateAvailableForLaunch", launchpadID, launchDate)
ret0, _ := ret[0].(bool)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// IsActive indicates an expected call of IsActive
-func (mr *MockLaunchpadRepositoryMockRecorder) IsActive(id interface{}) *gomock.Call {
+// IsDateAvailableForLaunch indicates an expected call of IsDateAvailableForLaunch.
+func (mr *MockLaunchpadRepositoryMockRecorder) IsDateAvailableForLaunch(launchpadID, launchDate any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsActive", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsActive), id)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsDateAvailableForLaunch", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsDateAvailableForLaunch), launchpadID, launchDate)
}
-// IsDateAvailableForLaunch mocks base method
-func (m *MockLaunchpadRepository) IsDateAvailableForLaunch(launchpadID string, launchDate time.Time) (bool, error) {
+// IsExists mocks base method.
+func (m *MockLaunchpadRepository) IsExists(id string) (bool, error) {
m.ctrl.T.Helper()
- ret := m.ctrl.Call(m, "IsDateAvailableForLaunch", launchpadID, launchDate)
+ ret := m.ctrl.Call(m, "IsExists", id)
ret0, _ := ret[0].(bool)
ret1, _ := ret[1].(error)
return ret0, ret1
}
-// IsDateAvailableForLaunch indicates an expected call of IsDateAvailableForLaunch
-func (mr *MockLaunchpadRepositoryMockRecorder) IsDateAvailableForLaunch(launchpadID, launchDate interface{}) *gomock.Call {
+// IsExists indicates an expected call of IsExists.
+func (mr *MockLaunchpadRepositoryMockRecorder) IsExists(id any) *gomock.Call {
mr.mock.ctrl.T.Helper()
- return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsDateAvailableForLaunch", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsDateAvailableForLaunch), launchpadID, launchDate)
+ return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "IsExists", reflect.TypeOf((*MockLaunchpadRepository)(nil).IsExists), id)
}
diff --git a/internal/usecase/booking_test.go b/internal/usecase/booking_test.go
index cee3ae5..2e73c3d 100644
--- a/internal/usecase/booking_test.go
+++ b/internal/usecase/booking_test.go
@@ -7,9 +7,9 @@ import (
"testing"
"time"
- "github.com/golang/mock/gomock"
"github.com/mgerasimchuk/space-trouble/internal/adapter/repository/mock"
"github.com/stretchr/testify/assert"
+ "go.uber.org/mock/gomock"
)
func TestBookingUsecase_VerifyBooking(t *testing.T) {
diff --git a/internal/usecase/repository/booking.go b/internal/usecase/repository/booking.go
index 798b93c..a2e23b9 100644
--- a/internal/usecase/repository/booking.go
+++ b/internal/usecase/repository/booking.go
@@ -4,6 +4,8 @@ import (
"github.com/mgerasimchuk/space-trouble/internal/entity"
)
+//go:generate mockgen -source=booking.go -destination=../../adapter/repository/mock/booking.go -package=mock
+
const DefaultBookingGetListLimit = 20
type BookingRepository interface {
diff --git a/internal/usecase/repository/landpad.go b/internal/usecase/repository/landpad.go
index eebae1c..f2c55db 100644
--- a/internal/usecase/repository/landpad.go
+++ b/internal/usecase/repository/landpad.go
@@ -1,5 +1,7 @@
package repository
+//go:generate mockgen -source=landpad.go -destination=../../adapter/repository/mock/landpad.go -package=mock
+
type LandpadRepository interface {
IsExists(id string) (bool, error)
IsActive(id string) (bool, error)
diff --git a/internal/usecase/repository/launchpad.go b/internal/usecase/repository/launchpad.go
index df7f9ef..fe819cf 100644
--- a/internal/usecase/repository/launchpad.go
+++ b/internal/usecase/repository/launchpad.go
@@ -2,6 +2,8 @@ package repository
import "time"
+//go:generate mockgen -source=launchpad.go -destination=../../adapter/repository/mock/launchpad.go -package=mock
+
type LaunchpadRepository interface {
IsExists(id string) (bool, error)
IsActive(id string) (bool, error)
diff --git a/test/integration/api/bookings_test.go b/test/integration/api/bookings_test.go
index 82a6f0c..9521e89 100644
--- a/test/integration/api/bookings_test.go
+++ b/test/integration/api/bookings_test.go
@@ -1,19 +1,15 @@
package main
import (
- "github.com/bxcodec/faker/v3"
"github.com/gavv/httpexpect/v2"
+ "github.com/go-faker/faker/v4"
"net/http"
"testing"
"time"
)
-func Test_Bookings_POST__ValidationError(t *testing.T) {
- t.Parallel()
- cfg := getConfig()
- e := httpexpect.Default(t, cfg.ServerURL)
-
- e.POST("/v1/bookings").
+func Test_Bookings_POST__EmptyBody_ValidationError(t *testing.T) {
+ getExpect(t).POST("/v1/bookings").
WithJSON(map[string]string{}).
Expect().
Status(http.StatusBadRequest).
diff --git a/test/integration/api/util_test.go b/test/integration/api/util_test.go
index d8d5775..18b75bc 100644
--- a/test/integration/api/util_test.go
+++ b/test/integration/api/util_test.go
@@ -1,7 +1,9 @@
package main
import (
+ "github.com/gavv/httpexpect/v2"
"github.com/kelseyhightower/envconfig"
+ "testing"
)
type config struct {
@@ -15,3 +17,9 @@ func getConfig() *config {
}
return cfg
}
+
+func getExpect(t *testing.T) *httpexpect.Expect {
+ t.Parallel()
+ cfg := getConfig()
+ return httpexpect.Default(t, cfg.ServerURL)
+}