code.vegaprotocol.io/vega@v0.79.0/commands/join_team_test.go (about)

     1  // Copyright (C) 2023 Gobalsky Labs Limited
     2  //
     3  // This program is free software: you can redistribute it and/or modify
     4  // it under the terms of the GNU Affero General Public License as
     5  // published by the Free Software Foundation, either version 3 of the
     6  // License, or (at your option) any later version.
     7  //
     8  // This program is distributed in the hope that it will be useful,
     9  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    10  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    11  // GNU Affero General Public License for more details.
    12  //
    13  // You should have received a copy of the GNU Affero General Public License
    14  // along with this program.  If not, see <http://www.gnu.org/licenses/>.
    15  
    16  package commands_test
    17  
    18  import (
    19  	"errors"
    20  	"testing"
    21  
    22  	"code.vegaprotocol.io/vega/commands"
    23  	vgtest "code.vegaprotocol.io/vega/libs/test"
    24  	commandspb "code.vegaprotocol.io/vega/protos/vega/commands/v1"
    25  
    26  	"github.com/stretchr/testify/assert"
    27  )
    28  
    29  func TestJoinTeam(t *testing.T) {
    30  	t.Run("Joining team succeeds", testJoiningTeamSucceeds)
    31  	t.Run("Joining team with team ID fails", testJoinTeamWithoutTeamIDFails)
    32  }
    33  
    34  func testJoiningTeamSucceeds(t *testing.T) {
    35  	err := checkJoinTeam(t, &commandspb.JoinTeam{
    36  		Id: vgtest.RandomVegaID(),
    37  	})
    38  
    39  	assert.Empty(t, err)
    40  }
    41  
    42  func testJoinTeamWithoutTeamIDFails(t *testing.T) {
    43  	err := checkJoinTeam(t, &commandspb.JoinTeam{
    44  		Id: "",
    45  	})
    46  
    47  	assert.Contains(t, err.Get("join_team.id"), commands.ErrShouldBeAValidVegaID)
    48  }
    49  
    50  func checkJoinTeam(t *testing.T, cmd *commandspb.JoinTeam) commands.Errors {
    51  	t.Helper()
    52  
    53  	err := commands.CheckJoinTeam(cmd)
    54  
    55  	var e commands.Errors
    56  	if ok := errors.As(err, &e); !ok {
    57  		return commands.NewErrors()
    58  	}
    59  
    60  	return e
    61  }