forked from Silverfish/proton-bridge
- Changed: Do not reauth controller clients. - Changed: Verbosisty is set only once before run - Changed: AddUser takes TestAccount as argument - Added: Setup/clean up before/after test run - Added: Access to the current refresh token from pmapi.Client interface. - Added: Context function to add test a user to bridge without login, just call users.FinishLogin. - Added: PMAPIController.GetAuthClient returns authenticated client for username. - Added: Persistent clients does not loggout after every scenario. - Changed: Disabled no-internet tests.
79 lines
2.4 KiB
Go
79 lines
2.4 KiB
Go
// Copyright (c) 2021 Proton Technologies AG
|
|
//
|
|
// This file is part of ProtonMail Bridge.Bridge.
|
|
//
|
|
// ProtonMail Bridge is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// ProtonMail Bridge is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with ProtonMail Bridge. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package fakeapi
|
|
|
|
import (
|
|
"sync"
|
|
|
|
"github.com/ProtonMail/proton-bridge/pkg/pmapi"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// Controller implements dummy PMAPIController interface without actual
|
|
// endpoint.
|
|
type Controller struct {
|
|
// Internal states.
|
|
lock *sync.RWMutex
|
|
fakeAPIs []*FakePMAPI
|
|
calls []*fakeCall
|
|
labelIDGenerator idGenerator
|
|
messageIDGenerator idGenerator
|
|
tokenGenerator idGenerator
|
|
clientManager *fakePMAPIManager
|
|
|
|
// State controlled by test.
|
|
noInternetConnection bool
|
|
usersByUsername map[string]*fakeUser
|
|
sessionsByUID map[string]*fakeSession
|
|
addressesByUsername map[string]*pmapi.AddressList
|
|
labelsByUsername map[string][]*pmapi.Label
|
|
messagesByUsername map[string][]*pmapi.Message
|
|
|
|
locker sync.Locker
|
|
log *logrus.Entry
|
|
}
|
|
|
|
func NewController() (*Controller, pmapi.Manager) {
|
|
controller := &Controller{
|
|
lock: &sync.RWMutex{},
|
|
fakeAPIs: []*FakePMAPI{},
|
|
calls: []*fakeCall{},
|
|
labelIDGenerator: 100, // We cannot use system label IDs.
|
|
messageIDGenerator: 0,
|
|
tokenGenerator: 1000, // No specific reason; 1000 simply feels right.
|
|
|
|
noInternetConnection: false,
|
|
usersByUsername: map[string]*fakeUser{},
|
|
sessionsByUID: map[string]*fakeSession{},
|
|
addressesByUsername: map[string]*pmapi.AddressList{},
|
|
labelsByUsername: map[string][]*pmapi.Label{},
|
|
messagesByUsername: map[string][]*pmapi.Message{},
|
|
|
|
locker: &sync.Mutex{},
|
|
log: logrus.WithField("pkg", "fakeapi-controller"),
|
|
}
|
|
|
|
cm := &fakePMAPIManager{
|
|
controller: controller,
|
|
}
|
|
|
|
controller.clientManager = cm
|
|
|
|
return controller, cm
|
|
}
|