package api import ( "fmt" "testing" "github.com/hermeznetwork/hermez-node/common" "github.com/hermeznetwork/hermez-node/db/historydb" "github.com/mitchellh/copystructure" "github.com/stretchr/testify/assert" ) type testCoordinatorsResponse struct { Coordinators []historydb.CoordinatorAPI `json:"coordinators"` PendingItems uint64 `json:"pendingItems"` } func (t testCoordinatorsResponse) GetPending() (pendingItems, lastItemID uint64) { if len(t.Coordinators) == 0 { return 0, 0 } pendingItems = t.PendingItems lastItemID = t.Coordinators[len(t.Coordinators)-1].ItemID return pendingItems, lastItemID } func (t *testCoordinatorsResponse) Len() int { return len(t.Coordinators) } func (t testCoordinatorsResponse) New() Pendinger { return &testCoordinatorsResponse{} } func genTestCoordinators(coordinators []common.Coordinator) []historydb.CoordinatorAPI { testCoords := []historydb.CoordinatorAPI{} for i := 0; i < len(coordinators); i++ { alreadyRegistered := false for j := 0; j < len(testCoords); j++ { // coordinator already registered if coordinators[i].Bidder == testCoords[j].Bidder { alreadyRegistered = true if coordinators[i].EthBlockNum > testCoords[j].EthBlockNum { // This occurrence is more updated, delete current and append new testCoords = append(testCoords[:j], testCoords[j+1:]...) alreadyRegistered = false } break } } if !alreadyRegistered { testCoords = append(testCoords, historydb.CoordinatorAPI{ Bidder: coordinators[i].Bidder, Forger: coordinators[i].Forger, EthBlockNum: coordinators[i].EthBlockNum, URL: coordinators[i].URL, }) } } return testCoords } func TestGetCoordinators(t *testing.T) { endpoint := apiURL + "coordinators" fetchedCoordinators := []historydb.CoordinatorAPI{} appendIter := func(intr interface{}) { for i := 0; i < len(intr.(*testCoordinatorsResponse).Coordinators); i++ { tmp, err := copystructure.Copy(intr.(*testCoordinatorsResponse).Coordinators[i]) if err != nil { panic(err) } fetchedCoordinators = append(fetchedCoordinators, tmp.(historydb.CoordinatorAPI)) } } // All limit := 5 path := fmt.Sprintf("%s?limit=%d", endpoint, limit) err := doGoodReqPaginated(path, historydb.OrderAsc, &testCoordinatorsResponse{}, appendIter) assert.NoError(t, err) assertCoordinators(t, tc.coordinators, fetchedCoordinators) // All in reverse order fetchedCoordinators = []historydb.CoordinatorAPI{} err = doGoodReqPaginated(path, historydb.OrderDesc, &testCoordinatorsResponse{}, appendIter) assert.NoError(t, err) reversedCoordinators := []historydb.CoordinatorAPI{} for i := 0; i < len(tc.coordinators); i++ { reversedCoordinators = append(reversedCoordinators, tc.coordinators[len(tc.coordinators)-1-i]) } assertCoordinators(t, reversedCoordinators, fetchedCoordinators) for _, filteredCoord := range tc.coordinators { // By bidder fetchedCoordinators = []historydb.CoordinatorAPI{} err = doGoodReqPaginated( fmt.Sprintf(path+"&bidderAddr=%s", filteredCoord.Bidder.String()), historydb.OrderAsc, &testCoordinatorsResponse{}, appendIter, ) assert.NoError(t, err) assertCoordinators(t, []historydb.CoordinatorAPI{filteredCoord}, fetchedCoordinators) // By forger fetchedCoordinators = []historydb.CoordinatorAPI{} err = doGoodReqPaginated( fmt.Sprintf(path+"&forgerAddr=%s", filteredCoord.Forger.String()), historydb.OrderAsc, &testCoordinatorsResponse{}, appendIter, ) assert.NoError(t, err) assertCoordinators(t, []historydb.CoordinatorAPI{filteredCoord}, fetchedCoordinators) } // Empty array fetchedCoordinators = []historydb.CoordinatorAPI{} path = fmt.Sprintf("%s?bidderAddr=0xaa942cfcd25ad4d90a62358b0dd84f33b398262a", endpoint) err = doGoodReqPaginated(path, historydb.OrderDesc, &testCoordinatorsResponse{}, appendIter) assert.NoError(t, err) assertCoordinators(t, []historydb.CoordinatorAPI{}, fetchedCoordinators) // 400 path = fmt.Sprintf("%s?bidderAddr=0x001", endpoint) err = doBadReq("GET", path, nil, 400) assert.NoError(t, err) } func assertCoordinator(t *testing.T, expected, actual historydb.CoordinatorAPI) { actual.ItemID = 0 assert.Equal(t, expected, actual) } func assertCoordinators(t *testing.T, expected, actual []historydb.CoordinatorAPI) { assert.Equal(t, len(expected), len(actual)) for i := 0; i < len(expected); i++ { assertCoordinator(t, expected[i], actual[i]) } }