blob: 7a69995f69138f3d1b159da9b737ba3161eeb2f3 [file] [log] [blame] [edit]
package apidApigeeSync
import (
"github.com/30x/apid-core"
"github.com/apigee-labs/transicator/common"
. "github.com/onsi/ginkgo"
"net/http/httptest"
"net/url"
"os"
"time"
)
var _ = Describe("Change Agent", func() {
Context("Change Agent Unit Tests", func() {
handler := handler{}
var createTestDb = func(sqlfile string, dbId string) common.Snapshot {
initDb(sqlfile, "./mockdb_change.sqlite3")
file, err := os.Open("./mockdb_change.sqlite3")
if err != nil {
Fail("Failed to open mock db for test")
}
s := common.Snapshot{}
err = processSnapshotServerFileResponse(dbId, file, &s)
if err != nil {
Fail("Error processing test snapshots")
}
return s
}
BeforeEach(func() {
event := createTestDb("./sql/init_mock_db.sql", "test_change")
handler.Handle(&event)
knownTables = extractTablesFromDB(getDB())
})
var initializeContext = func() {
testRouter = apid.API().Router()
testServer = httptest.NewServer(testRouter)
// set up mock server
mockParms := MockParms{
ReliableAPI: true,
ClusterID: config.GetString(configApidClusterId),
TokenKey: config.GetString(configConsumerKey),
TokenSecret: config.GetString(configConsumerSecret),
Scope: "ert452",
Organization: "att",
Environment: "prod",
}
testMock = Mock(mockParms, testRouter)
config.Set(configProxyServerBaseURI, testServer.URL)
config.Set(configSnapServerBaseURI, testServer.URL)
config.Set(configChangeServerBaseURI, testServer.URL)
config.Set(configPollInterval, 1*time.Millisecond)
}
var restoreContext = func() {
testServer.Close()
config.Set(configProxyServerBaseURI, dummyConfigValue)
config.Set(configSnapServerBaseURI, dummyConfigValue)
config.Set(configChangeServerBaseURI, dummyConfigValue)
config.Set(configPollInterval, 10*time.Millisecond)
}
It("test change agent with authorization failure", func() {
log.Debug("test change agent with authorization failure")
testTokenManager := &dummyTokenManager{make(chan bool)}
apidTokenManager = testTokenManager
apidTokenManager.start()
apidSnapshotManager = &dummySnapshotManager{}
initializeContext()
testMock.forceAuthFail()
wipeDBAferTest = true
apidChangeManager.pollChangeWithBackoff()
// auth check fails
<-testTokenManager.invalidateChan
log.Debug("closing")
<-apidChangeManager.close()
restoreContext()
})
It("test change agent with too old snapshot", func() {
log.Debug("test change agent with too old snapshot")
testTokenManager := &dummyTokenManager{make(chan bool)}
apidTokenManager = testTokenManager
apidTokenManager.start()
testSnapshotManager := &dummySnapshotManager{make(chan bool)}
apidSnapshotManager = testSnapshotManager
initializeContext()
testMock.passAuthCheck()
testMock.forceNewSnapshot()
wipeDBAferTest = true
apidChangeManager.pollChangeWithBackoff()
<-testSnapshotManager.downloadCalledChan
log.Debug("closing")
<-apidChangeManager.close()
restoreContext()
})
It("change agent should retry with authorization failure", func(done Done) {
log.Debug("change agent should retry with authorization failure")
testTokenManager := &dummyTokenManager{make(chan bool)}
apidTokenManager = testTokenManager
apidTokenManager.start()
apidSnapshotManager = &dummySnapshotManager{}
initializeContext()
testMock.forceAuthFail()
testMock.forceNoSnapshot()
wipeDBAferTest = true
apid.Events().ListenFunc(ApigeeSyncEventSelector, func(event apid.Event) {
if _, ok := event.(*common.ChangeList); ok {
closeDone := apidChangeManager.close()
log.Debug("closing")
go func() {
// when close done, all handlers for the first snapshot have been executed
<-closeDone
restoreContext()
close(done)
}()
}
})
apidChangeManager.pollChangeWithBackoff()
// auth check fails
<-testTokenManager.invalidateChan
})
})
})
type dummyTokenManager struct {
invalidateChan chan bool
}
func (t *dummyTokenManager) getBearerToken() string {
return ""
}
func (t *dummyTokenManager) invalidateToken() error {
log.Debug("invalidateToken called")
testMock.passAuthCheck()
t.invalidateChan <- true
return nil
}
func (t *dummyTokenManager) getToken() *oauthToken {
return nil
}
func (t *dummyTokenManager) close() {
return
}
func (t *dummyTokenManager) getRetrieveNewTokenClosure(*url.URL) func(chan bool) error {
return func(chan bool) error {
return nil
}
}
func (t *dummyTokenManager) start() {
}
type dummySnapshotManager struct {
downloadCalledChan chan bool
}
func (s *dummySnapshotManager) close() <-chan bool {
closeChan := make(chan bool)
close(closeChan)
return closeChan
}
func (s *dummySnapshotManager) downloadBootSnapshot() {
}
func (s *dummySnapshotManager) storeBootSnapshot(snapshot *common.Snapshot) {
}
func (s *dummySnapshotManager) downloadDataSnapshot() {
log.Debug("dummySnapshotManager.downloadDataSnapshot() called")
s.downloadCalledChan <- true
}
func (s *dummySnapshotManager) storeDataSnapshot(snapshot *common.Snapshot) {
}
func (s *dummySnapshotManager) downloadSnapshot(scopes []string, snapshot *common.Snapshot) error {
return nil
}