Skip to content

Commit

Permalink
feat: GET /tournament/teams API endoint
Browse files Browse the repository at this point in the history
  • Loading branch information
moul committed Oct 6, 2019
1 parent ae1bc1d commit 0b78844
Show file tree
Hide file tree
Showing 15 changed files with 972 additions and 320 deletions.
2 changes: 2 additions & 0 deletions api/pwdb.proto
Original file line number Diff line number Diff line change
Expand Up @@ -344,6 +344,8 @@ message TournamentTeam {
repeated TournamentMember members = 206 [(gogoproto.moretags) = "gorm:\"PRELOAD:false\""];
}

message TournamentTeamList { repeated TournamentTeam items = 1; }

message WhoswhoAttempt {
string id = 1 [(gogoproto.moretags) = "gorm:\"primary_key\"", (gogoproto.customname) = "ID"];
google.protobuf.Timestamp created_at = 2 [(gogoproto.stdtime) = true, (gogoproto.nullable) = true];
Expand Down
5 changes: 5 additions & 0 deletions api/pwengine.proto
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ service Engine {
rpc SetPreferences(SetPreferencesInput) returns (Void) { option (google.api.http) = {post: "/preferences"}; };
rpc ListLevels(Void) returns (pathwar.db.LevelList) { option (google.api.http) = {get: "/levels"}; };
rpc ListTeams(Void) returns (pathwar.db.TeamList) { option (google.api.http) = {get: "/teams"}; };
rpc ListTournamentTeams(ListTournamentTeamsInput) returns (pathwar.db.TournamentTeamList) { option (google.api.http) = {get: "/tournament/teams"}; };
rpc GetStatus(Void) returns (Status) { option (google.api.http) = {get: "/status"}; }

//
Expand All @@ -111,6 +112,10 @@ message Void {
};
}

message ListTournamentTeamsInput {
string tournament_id = 1 [(gogoproto.customname) = "TournamentID"];
}

message SetPreferencesInput {
string active_tournament_id = 1 [(gogoproto.customname) = "ActiveTournamentID"];
// bool dark_mode
Expand Down
4 changes: 2 additions & 2 deletions docs/gen.sum
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
03acd307b08ec4c03ccfb8c4c0620f573612a5b2 ../api/pwlevel.proto
0de9739f87fa0d19673b7d757bcd13a081d710ca ../api/pwengine.proto
30302d31bca0924719daf9e95a0ea15dfbcfb131 ../api/pwhypervisor.proto
3d7019edce77afca17dce1ea2be49cf9e406ff5d ../api/pwengine.proto
58eb4b1d9b5be40a69ffdab1a13b9fb90b669839 ../api/pwsso.proto
5d333f98cfbafd36ddc97b3c7c364bf94b898384 ../api/pwcompose.proto
71351a6ac01962fbeaeeeafd431d481e6c1f288b Makefile
bcbb91db20d1b10a3a19757fc010af0409740d4b ../api/pwdb.proto
db9d6a9a49123ed17cd2cb8afb02b22257df34ef ../api/pwdb.proto
4 changes: 2 additions & 2 deletions go/gen.sum
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
006d046d6df55771deca224d63b6bba42a606e4a Makefile
03acd307b08ec4c03ccfb8c4c0620f573612a5b2 ../api/pwlevel.proto
0de9739f87fa0d19673b7d757bcd13a081d710ca ../api/pwengine.proto
30302d31bca0924719daf9e95a0ea15dfbcfb131 ../api/pwhypervisor.proto
3d7019edce77afca17dce1ea2be49cf9e406ff5d ../api/pwengine.proto
58eb4b1d9b5be40a69ffdab1a13b9fb90b669839 ../api/pwsso.proto
5d333f98cfbafd36ddc97b3c7c364bf94b898384 ../api/pwcompose.proto
bcbb91db20d1b10a3a19757fc010af0409740d4b ../api/pwdb.proto
db9d6a9a49123ed17cd2cb8afb02b22257df34ef ../api/pwdb.proto
1 change: 0 additions & 1 deletion go/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ require (
github.com/brianvoe/gofakeit v3.18.0+incompatible
github.com/dgrijalva/jwt-go v3.2.0+incompatible
github.com/go-chi/chi v4.0.2+incompatible
github.com/go-errors/errors v1.0.1
github.com/go-sql-driver/mysql v1.4.1
github.com/gobuffalo/packr/v2 v2.6.0
github.com/gogo/gateway v1.1.0
Expand Down
2 changes: 0 additions & 2 deletions go/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,6 @@ github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMo
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
github.com/go-chi/chi v4.0.2+incompatible h1:maB6vn6FqCxrpz4FqWdh4+lwpyZIQS7YEAUcHlgXVRs=
github.com/go-chi/chi v4.0.2+incompatible/go.mod h1:eB3wogJHnLi3x/kFX2A+IbTBlXxmMeXJVKy9tTv1XzQ=
github.com/go-errors/errors v1.0.1 h1:LUHzmkK3GUKUrL/1gfBUxAHzcev3apQlezX/+O7ma6w=
github.com/go-errors/errors v1.0.1/go.mod h1:f4zRHt4oKfwPJE5k8C9vpYG+aDHdBFUsgrm6/TyX73Q=
github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE=
github.com/go-sql-driver/mysql v1.4.1 h1:g24URVg0OFbNUTx9qqY1IRZ9D9z3iPyi5zKhQZpNwpA=
Expand Down
651 changes: 418 additions & 233 deletions go/pkg/pwdb/pwdb.pb.go

Large diffs are not rendered by default.

42 changes: 42 additions & 0 deletions go/pkg/pwengine/api_pub_listtournamentteams.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
package pwengine

import (
"context"
"fmt"

"pathwar.land/go/pkg/pwdb"
)

func (e *engine) ListTournamentTeams(ctx context.Context, in *ListTournamentTeamsInput) (*pwdb.TournamentTeamList, error) {
{ // validation
if in.TournamentID == "" {
return nil, ErrMissingArgument
}

var c int
err := e.db.
Table("tournament").
Select("id").
Where("id = ?", in.TournamentID).
Count(&c).
Error
if err != nil {
return nil, fmt.Errorf("failed to fetch tournament: %w", err)
}
if c == 0 {
return nil, ErrInvalidArgument // invalid in.TournamentID
}
}

var ret pwdb.TournamentTeamList
err := e.db.
Set("gorm:auto_preload", true).
Where(pwdb.TournamentTeam{TournamentID: in.TournamentID}).
Find(&ret.Items).
Error
if err != nil {
return nil, fmt.Errorf("failed to fetch tournament teams from db: %w", err)
}

return &ret, nil
}
73 changes: 73 additions & 0 deletions go/pkg/pwengine/api_pub_listtournamentteams_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
package pwengine

import (
"context"
"errors"
"testing"
)

func TestEngine_ListTournamentTeams(t *testing.T) {
engine, cleanup := TestingEngine(t, Opts{})
defer cleanup()
ctx := testSetContextToken(t, context.Background())

// FIXME: check for permissions

tournaments := map[string]string{}
for _, tournament := range testingTournaments(t, engine).Items {
tournaments[tournament.Name] = tournament.ID
}

var tests = []struct {
name string
input *ListTournamentTeamsInput
expectedErr error
expectedTeams int
// expectedOwnedTeams int?
}{
{
"empty",
&ListTournamentTeamsInput{},
ErrMissingArgument,
0,
}, {
"unknown-tournament-id",
&ListTournamentTeamsInput{TournamentID: "does not exist"},
ErrInvalidArgument,
0,
}, {
"solo-mode",
&ListTournamentTeamsInput{TournamentID: tournaments["Solo Mode"]},
nil,
1,
}, {
"test-tournament",
&ListTournamentTeamsInput{TournamentID: tournaments["Test Tournament"]},
nil,
0,
},
}

for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
ret, err := engine.ListTournamentTeams(ctx, test.input)
if !errors.Is(err, test.expectedErr) {
t.Fatalf("Expected %#v, got %#v.", test.expectedErr, err)
}
if err != nil {
return
}

// fmt.Println(godev.PrettyJSON(ret))
for _, team := range ret.Items {
if team.TournamentID != test.input.TournamentID {
t.Fatalf("Expected %q, got %q.", test.input.TournamentID, team.TournamentID)
}
}

if len(ret.Items) != test.expectedTeams {
t.Fatalf("Expected %d, got %d.", test.expectedTeams, len(ret.Items))
}
})
}
}
2 changes: 1 addition & 1 deletion go/pkg/pwengine/api_pub_setpreferences.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ func (e *engine) SetPreferences(ctx context.Context, in *SetPreferencesInput) (*
var tournamentIDs []string
err := e.db.
Table("tournament").
Where("ID = ?", in.ActiveTournamentID).
Where("id = ?", in.ActiveTournamentID).
Pluck("id", &tournamentIDs).
Error
switch {
Expand Down
3 changes: 1 addition & 2 deletions go/pkg/pwengine/api_pub_setpreferences_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,8 @@ package pwengine

import (
"context"
"errors"
"testing"

"github.com/go-errors/errors"
)

func TestEngine_SetPreferences(t *testing.T) {
Expand Down
Loading

0 comments on commit 0b78844

Please sign in to comment.