// Copyright 2018 Vulcanize // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package flip_kick_test import ( . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" "github.com/vulcanize/vulcanizedb/pkg/datastore/postgres" "github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories" "github.com/vulcanize/vulcanizedb/pkg/fakes" "github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick" "github.com/vulcanize/vulcanizedb/pkg/transformers/shared/constants" "github.com/vulcanize/vulcanizedb/pkg/transformers/test_data" "github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/shared_behaviors" "github.com/vulcanize/vulcanizedb/test_config" ) var _ = Describe("FlipKick Repository", func() { var db *postgres.DB var flipKickRepository flip_kick.FlipKickRepository BeforeEach(func() { db = test_config.NewTestDB(test_config.NewTestNode()) test_config.CleanTestDB(db) flipKickRepository = flip_kick.FlipKickRepository{} flipKickRepository.SetDB(db) }) Describe("Create", func() { modelWithDifferentLogIdx := test_data.FlipKickModel modelWithDifferentLogIdx.LogIndex++ inputs := shared_behaviors.CreateBehaviorInputs{ CheckedHeaderColumnName: constants.FlipKickChecked, LogEventTableName: "maker.flip_kick", TestModel: test_data.FlipKickModel, ModelWithDifferentLogIdx: modelWithDifferentLogIdx, Repository: &flipKickRepository, } shared_behaviors.SharedRepositoryCreateBehaviors(&inputs) It("persists flip_kick records", func() { headerRepository := repositories.NewHeaderRepository(db) headerId, err := headerRepository.CreateOrUpdateHeader(fakes.FakeHeader) Expect(err).NotTo(HaveOccurred()) err = flipKickRepository.Create(headerId, []interface{}{test_data.FlipKickModel}) Expect(err).NotTo(HaveOccurred()) assertDBRecordCount(db, "maker.flip_kick", 1) dbResult := test_data.FlipKickDBRow{} err = db.QueryRowx(`SELECT * FROM maker.flip_kick`).StructScan(&dbResult) Expect(err).NotTo(HaveOccurred()) Expect(dbResult.HeaderId).To(Equal(headerId)) Expect(dbResult.BidId).To(Equal(test_data.FlipKickModel.BidId)) Expect(dbResult.Lot).To(Equal(test_data.FlipKickModel.Lot)) Expect(dbResult.Bid).To(Equal(test_data.FlipKickModel.Bid)) Expect(dbResult.Gal).To(Equal(test_data.FlipKickModel.Gal)) Expect(dbResult.End.Equal(test_data.FlipKickModel.End)).To(BeTrue()) Expect(dbResult.Urn).To(Equal(test_data.FlipKickModel.Urn)) Expect(dbResult.Tab).To(Equal(test_data.FlipKickModel.Tab)) Expect(dbResult.TransactionIndex).To(Equal(test_data.FlipKickModel.TransactionIndex)) Expect(dbResult.LogIndex).To(Equal(test_data.FlipKickModel.LogIndex)) Expect(dbResult.Raw).To(MatchJSON(test_data.FlipKickModel.Raw)) }) }) Describe("MarkHeaderChecked", func() { inputs := shared_behaviors.MarkedHeaderCheckedBehaviorInputs{ CheckedHeaderColumnName: constants.FlipKickChecked, Repository: &flipKickRepository, } shared_behaviors.SharedRepositoryMarkHeaderCheckedBehaviors(&inputs) }) Describe("missing headers", func() { inputs := shared_behaviors.MissingHeadersBehaviorInputs{ Repository: &flipKickRepository, RepositoryTwo: &flip_kick.FlipKickRepository{}, } shared_behaviors.SharedRepositoryMissingHeadersBehaviors(&inputs) }) }) func assertDBRecordCount(db *postgres.DB, dbTable string, expectedCount int) { var count int query := `SELECT count(*) FROM ` + dbTable err := db.QueryRow(query).Scan(&count) Expect(err).NotTo(HaveOccurred()) Expect(count).To(Equal(expectedCount)) }