forked from Ivasoft/mattermost-mobile
* MM_35115: ADDED select_server screen
* MM_35115: ADDED select_server screen
* MM_35115: ADDED files on which select_server is dependent
* MM_35115: ADDED react-native-button
* MM_35115: Fixing TS issues [IN PROGRESS]
* MM_35115: Started withObservables [IN PROGRESS]
* MM_35115: Started withObservables [IN PROGRESS]
* MM_35115: withObservables - defaulting when no connection is available [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: withObservables - some code clean up [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Substituting mapDispatchToProps [IN PROGRESS]
* MM_35115: Removed resetPing action [IN PROGRESS]
* MM_35115: ADDED app/client
* MM_35115: Preparing scheduleExpiredNotification
* MM_35115: Adding some todos
* Server & LoginOptions
* Use default server if available and autoconnect if configured
* Fix login header & manual server url
* MM_35115: Login Options[IN PROGRESS]
* MM_35115: Login screen - email [IN PROGRESS]
* MM_35115: Login screen - email [IN PROGRESS]
* MM_35115: Login screen - email - login api call [IN PROGRESS]
* MM_35115: Login screen - email - login api call [IN PROGRESS]
* MM_35115: Login screen - email - saving to server db [IN PROGRESS]
* MM_35115: Login screen - email - saving to System, Preferences to db [IN PROGRESS]
* MM_35115: Login screen - enforcing unique check on System entity [IN PROGRESS]
* MM_35115: Login screen - writing TeamMembership [IN PROGRESS]
* MM_35115: Login screen - writing Teams [IN PROGRESS]
* MM_35115: Login screen [IN PROGRESS]
* MM_35115: Login screen- Refactored DataOperator handlers [IN PROGRESS]
* MM_35115: Login screen - Proper clean up [IN PROGRESS]
* MM_35115: Login screen - completeLogin [IN PROGRESS]
* MM_35115: Improving DataOperator
* MM_35115: Improving DataOperator
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: 80% DONE - login with email and password - some todos
* MM_35115: Removing unused app/queries folder
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Clean up
* MM_35115: Adding roles for MYTEAM
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Adding rn-fetch-blob for Android
* MM_35115: Code clean up
* MM_35115: Code clean up
* MM_35115: Added test setup
* MM_35115: Fix database utils
* MM_35115: ADDED loadRolesIfNeeded
* MM_35115: Fix TS issue
* MM_35115: ADDED Tests setup
* MM_35115: Fix TS issues
* MM_35115: Fix TS issues
* MM_35115: Fix TS issues
* MM_35115: Added alternative to site name
* MM_35115: Added alternative to site name
* MM_35115: Removed hardcoded values
* MM_35115: Clean up
* MM_35115 - Fixed Android platform check instead of hermes
* MM_35115 - Replaced emptyErrorHandlingFunction with emptyFunction
* MM_35115 : Implemented TS fixes
* Update index.ts
* MM-35115 - Fix react-test-renderer issue
* MM_35115 - Optimizing DatabaseManager
* MM_35115 : Implemented getDatabaseConnection
* MM_35115 : Refactoring set/getActiveDatabase to use flag record
* MM_35115 : Refactored active database to use flag in Global entity
* MM_35115 : Updated manual database manager test
* MM_35115 : Fix operator/utils/test
* MM_35115 : Fix for base_handler
* MM_35115 : Fix test issues with Handlers
* MM_35115 : Fix test issues with prepareRecords
* MM_35115 : Fix wrapper test issue
* MM_35115 : Updated getMostRecentServerConnection to return the serverUrl as well as the connection
* MM_35115 : Refactored the way we call DataOperator
* MM_35115 : Updated database manager mock
* Add getMostRecentServerUrl function (#5440)
* fix: add getMostRecentServerUrl func
* fix: add ts and tsx to editorconfig
* fix: rename functions
* fix: return type
* Fix unit test setup
* fix login screen unit tests
* MM-36205 [GEKIDOU] Login Flow SSO (#5454)
* MM_35115: Starting LoginOptions SSO
* MM_36205: SSO [IN PROGRESS]
* MM_36205 : SSO [ IN PROGRESS ]
* Update sso_with_redirect_url.tsx
* MM_36205 : SSO Tests [ IN PROGRESS ]
* MM_36205 : Passing serverUrl to SSO screen
* Update sso.test.tsx
* Fix ViewTypes imports and keyMirror method
* MM_36205 : Code clean up
* Fix : Clean up imports
* Update: Aligning with PR 5452
* Fix: AndroidManifest file to include redirection ofr scheme mmauthbeta
* refactor: SSO Login method via Gitlab now navigates to Channel screen
* refactor: SSO Login without redirectURL is also working
* feat: SSO - main test completed
* feat: ADDED test for sso_with_redirect_url
* fix : eslint correction
* fix: Updated Loading component name
* fix : code clean up from reviews
* fix: reviews check
* fix: Added mmauthbeta into info.plist
* Revert "fix: Added mmauthbeta into info.plist"
This reverts commit d87cc23f5b.
* Update Info.plist
* Update AppDelegate.m
* feat: ADDED Forgot Password - Test [ IN PROGRESS ]
* feat: Forgot Password - Completed & Tested
* fix: Including MFA screen [ IN PROGRESS ]
* MFA - Properly tested
* Properly testing forgot_password screen
* Fix login.test.tsx
* Fix SSO method calls chain
* Update index.tsx
* Sort imports for sceen/navigation
* fix: Reviews
* Update signing + act in test
* Removed todo comment on MFA
* feedback review
* fix login tests
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
* App initialization refactor (#5430)
* fix: initial init refactor
* fix: await isServerPresent
* fix: more refactor
* fix: move out launch functions
* fix: remove comment
* fix: update credential functions
* fix: refactor launch functions
* fix: deep link parsing
* fix: lint change
* fix: update deeplink and notification handlers
* fix: indentation
* fix: add relaunchApp
* fix eslint
* refactor launchProps and autoconnect server for deeplink
* fix: use undefined
* fix: define OptionalLaunchProps
* fix: Android - handle server URL in push notification
* fix: rename func
* fix: use boolean launchError instead
* fix: use DatabaseModule
* fix: use DatabaseHelper instead
* fix: remove unnecessary null check
* fix: iOS - support for serverUrl
* fix: iOS - extract serverUrl in reply action
* fix: iOS - expose objc specific func
* fix: remove unnecessary deviceToken param
* fix: return if device is untrusted
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
* fix: bye bye modulePaths
* fix: ios build
* chore: remove unused aliases from babel.config
* chore: fix dependency format in package-lock.json
* chore: remove transparent window background color for android AppTheme
* chore: remove mattermost.js and use index.ts as app entry
* fix: login flow screens theme
* fix: Launch types
* chore: remove OptionalLaunchProps type
* fix: url utils unit tests
* chore: update en.json
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
237 lines
9.5 KiB
TypeScript
237 lines
9.5 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {Database, Q} from '@nozbe/watermelondb';
|
|
|
|
import {MM_TABLES} from '@constants/database';
|
|
import {DatabaseType} from '@typings/database/enums';
|
|
import IGlobal from '@typings/database/global';
|
|
import IServers from '@typings/database/servers';
|
|
|
|
import DatabaseManager from '@database/manager';
|
|
|
|
jest.mock('@database/manager');
|
|
|
|
const {GLOBAL, SERVERS} = MM_TABLES.DEFAULT;
|
|
const RECENTLY_VIEWED_SERVERS = 'RECENTLY_VIEWED_SERVERS';
|
|
|
|
// NOTE : On the mock Database Manager, we cannot test for :
|
|
// 1. Android/iOS file path
|
|
// 2. Deletion of the 'databases' folder on those two platforms
|
|
|
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
|
|
describe('*** Database Manager tests ***', () => {
|
|
let databaseManagerClient: DatabaseManager | null;
|
|
|
|
beforeEach(() => {
|
|
databaseManagerClient = new DatabaseManager();
|
|
});
|
|
|
|
afterEach(() => {
|
|
databaseManagerClient = null;
|
|
});
|
|
|
|
const createTwoConnections = async () => {
|
|
await databaseManagerClient!.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName: 'connection1',
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl: 'https://appv1.mattermost.com',
|
|
},
|
|
});
|
|
await databaseManagerClient!.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName: 'connection2',
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl: 'https://appv2.mattermost.com',
|
|
},
|
|
});
|
|
};
|
|
|
|
it('=> should return a default database', async () => {
|
|
expect.assertions(2);
|
|
|
|
const spyOnAddServerToDefaultDatabase = jest.spyOn(databaseManagerClient as any, 'addServerToDefaultDatabase');
|
|
|
|
const defaultDB = await databaseManagerClient!.getDefaultDatabase();
|
|
|
|
expect(defaultDB).toBeInstanceOf(Database);
|
|
expect(spyOnAddServerToDefaultDatabase).not.toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('=> should create a new server connection', async () => {
|
|
expect.assertions(2);
|
|
|
|
const spyOnAddServerToDefaultDatabase = jest.spyOn(databaseManagerClient as any, 'addServerToDefaultDatabase');
|
|
|
|
const connection1 = await databaseManagerClient!.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName: 'community mattermost',
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl: 'https://appv1.mattermost.com',
|
|
},
|
|
});
|
|
|
|
expect(connection1).toBeInstanceOf(Database);
|
|
expect(spyOnAddServerToDefaultDatabase).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it('=> should switch between active server connections', async () => {
|
|
expect.assertions(6);
|
|
let adapter;
|
|
|
|
const activeServerA = await databaseManagerClient!.getActiveServerDatabase();
|
|
|
|
// as we haven't set an active server yet, we should be getting undefined in the activeServer variable
|
|
expect(activeServerA).toBeUndefined();
|
|
|
|
const setActiveServer = async (serverUrl: string) => {
|
|
// now we set the active database
|
|
await databaseManagerClient!.setActiveServerDatabase(serverUrl);
|
|
};
|
|
|
|
await setActiveServer('https://appv1.mattermost.com');
|
|
|
|
// let's verify if we now have a value for activeServer
|
|
const activeServerB = await databaseManagerClient!.getActiveServerDatabase();
|
|
expect(activeServerB).toBeDefined();
|
|
|
|
adapter = activeServerB!.adapter as any;
|
|
const currentDBName = adapter.underlyingAdapter._dbName;
|
|
expect(currentDBName).toStrictEqual('appv1.mattermost.com');
|
|
|
|
// spice things up; we'll set a new server and verify if the value of activeServer changes
|
|
await setActiveServer('https://appv2.mattermost.com');
|
|
const activeServerC = await databaseManagerClient!.getActiveServerDatabase();
|
|
expect(activeServerC).toBeDefined();
|
|
|
|
adapter = activeServerC!.adapter as any;
|
|
const newDBName = adapter.underlyingAdapter._dbName;
|
|
expect(newDBName).toStrictEqual('appv2.mattermost.com');
|
|
|
|
const defaultDatabase = await databaseManagerClient!.getDefaultDatabase();
|
|
const records = await defaultDatabase!.collections.get(MM_TABLES.DEFAULT.GLOBAL).query(Q.where('name', 'RECENTLY_VIEWED_SERVERS')).fetch() as IGlobal[];
|
|
const recentlyViewedServers = records?.[0]?.value;
|
|
expect(recentlyViewedServers?.length).toBe(2);
|
|
});
|
|
|
|
it('=> should retrieve all database instances matching serverUrls parameter', async () => {
|
|
expect.assertions(3);
|
|
|
|
await createTwoConnections();
|
|
|
|
const spyOnCreateDatabaseConnection = jest.spyOn(databaseManagerClient!, 'createDatabaseConnection');
|
|
|
|
const dbInstances = await databaseManagerClient!.retrieveDatabaseInstances([
|
|
'https://xunity2.mattermost.com',
|
|
'https://appv2.mattermost.com',
|
|
'https://appv1.mattermost.com',
|
|
]);
|
|
|
|
expect(dbInstances).toBeTruthy();
|
|
const numDbInstances = dbInstances?.length ?? 0;
|
|
|
|
// The Database Manager will call the 'createDatabaseConnection' method in consequence of the number of database connection present in dbInstances array
|
|
expect(spyOnCreateDatabaseConnection).toHaveBeenCalledTimes(numDbInstances);
|
|
|
|
// We should have two active database connection
|
|
expect(numDbInstances).toEqual(2);
|
|
});
|
|
|
|
it('=> should retrieve existing database instances matching serverUrl parameter', async () => {
|
|
expect.assertions(2);
|
|
await createTwoConnections();
|
|
const spyOnRetrieveDatabaseInstances = jest.spyOn(databaseManagerClient!, 'retrieveDatabaseInstances');
|
|
const connection = await databaseManagerClient!.getDatabaseConnection({serverUrl: 'https://appv1.mattermost.com', setAsActiveDatabase: false});
|
|
expect(spyOnRetrieveDatabaseInstances).toHaveBeenCalledTimes(1);
|
|
expect(connection).toBeDefined();
|
|
});
|
|
|
|
//todo: test the current active database together with the getDatabaseConnection method
|
|
|
|
it('=> should have records of Servers set in the servers table of the default database', async () => {
|
|
expect.assertions(3);
|
|
|
|
const defaultDB = await databaseManagerClient!.getDefaultDatabase();
|
|
expect(defaultDB).toBeDefined();
|
|
await createTwoConnections();
|
|
const serversRecords = await defaultDB!.collections.get(SERVERS).query().fetch() as IServers[];
|
|
expect(serversRecords).toBeDefined();
|
|
|
|
// We have call the 'DatabaseManager.setActiveServerDatabase' twice in the previous test case; that implies that we have 2 records in the 'servers' table
|
|
expect(serversRecords.length).toEqual(2);
|
|
});
|
|
|
|
it('=> should delete appv1 server from the servers table of Default database', async () => {
|
|
expect.assertions(3);
|
|
await createTwoConnections();
|
|
|
|
const defaultDatabase = await databaseManagerClient!.getDefaultDatabase();
|
|
|
|
await databaseManagerClient?.setActiveServerDatabase('https://appv1.mattermost.com');
|
|
await databaseManagerClient?.setActiveServerDatabase('https://appv2.mattermost.com');
|
|
|
|
const fetchGlobalRecords = async () => {
|
|
const initialGlobalRecords = await defaultDatabase!.collections.get(GLOBAL).query(Q.where('name', RECENTLY_VIEWED_SERVERS)).fetch() as IGlobal[];
|
|
return initialGlobalRecords?.[0].value as string[];
|
|
};
|
|
|
|
const recentServers = await fetchGlobalRecords();
|
|
expect(recentServers.length).toBe(2);
|
|
|
|
// Removing database for appv1 connection
|
|
const isAppV1Removed = await databaseManagerClient!.deleteDatabase('https://appv1.mattermost.com');
|
|
expect(isAppV1Removed).toBe(true);
|
|
|
|
// Verifying in the database to confirm if its record was deleted
|
|
|
|
const updatedRecentServers = await fetchGlobalRecords();
|
|
expect(updatedRecentServers.length).toBe(1);
|
|
});
|
|
|
|
it('=> should enforce uniqueness of connections using serverUrl as key', async () => {
|
|
expect.assertions(2);
|
|
|
|
// We can't have more than one connection with the same server url
|
|
const serverUrl = 'https://appv3.mattermost.com';
|
|
await databaseManagerClient!.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName: 'community mattermost',
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl,
|
|
},
|
|
});
|
|
|
|
await databaseManagerClient!.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName: 'duplicate server',
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl,
|
|
},
|
|
});
|
|
|
|
const defaultDB = await databaseManagerClient!.getDefaultDatabase();
|
|
|
|
const allServers = defaultDB && await defaultDB.collections.get(SERVERS).query().fetch() as IServers[];
|
|
|
|
// We should be having some servers returned here
|
|
expect(allServers?.length).toBeGreaterThan(0);
|
|
|
|
const occurrences = allServers?.map((server) => server.url).reduce((acc, cur) => (cur === serverUrl ? acc + 1 : acc), 0);
|
|
|
|
// We should only have one occurrence of the 'https://appv3.mattermost.com' url
|
|
expect(occurrences).toEqual(1);
|
|
});
|
|
});
|