forked from Ivasoft/mattermost-mobile
* MM_30475 : ADDED default schema
* MM_30475 : ADDED todo for field 'value' of default/Global entity
* MM_30476 : Created schema for SERVER DB
* MM_30476 : Server model [ IN PROGRESS ]
* MM_30476 : Including types for group, groups_in_channel and role
* MM_30476 : ADDED models for Group
- @typings absolute path has been added to the tsconfig.json
* MM_30476 : ADDED typings to current models
* MM_30476 : ADDED typings to current models
* MM_30476 : ADDED models related to TEAM section of the ERD
* MM_30476 : ADDED models for User section of the ERD
* MM_30476 : ADDED models for POST section of the ERD
* MM_30476 : ADDED models for Channel section of the ERD
* MM_30475 : Updated typings and references to MM_TABLES
* MM_30476 : Verified all field names
* MM_30476 : Verified every table associations
* MM_30476 : Verified all relation fields
* MM_30476 : Updated primary id of the main models
We will override the wdb id at component level when we create a new records. This involves the models : channel, group, post, team and user.
* MM_30476 : Including 1:1 relationship amongs some entities
* MM_30476 : ADDED Schema Managers
* The migration array will hold all the migration steps.
* The initial app release (e.g. v2 )will have an empty array and subsequent releases (e.g. v2.1 ) will have the steps listed in that array.
* On initialization, the database will perform the migration to accomodate for new columns/tables creation and while it will conserve the mobile phone's data, it will also make it conform to this new schema.
* If a migration fails, the migration process will rollback any changes. This migration will be thoroughly tested in development before pushing it live.
* Revert "MM_30476 : ADDED Schema Managers"
This reverts commit a505bd5e11.
* MM_30478 : Converted schema_manager into a function
* MM_30478 : Updated schema manager and included patch for wdb
* MM_30478: Updated watermelondb patch package
* MM_30478 : Update function create_schema_manager to createSqliteAdaptorOptions
* MM_30476 : Update constant name to reflect directory name
* MM_30476 : Updated msgCount from my_channel model to message_count in server schema
* MM_30482 : Added tests for schema_manager
* MM_30482 : Database Manager [ IN PROGRESS ]
* MM_30478 : Returning an sqliteAdapter instead of an object
* MM_30476 : Apply suggestions from code review
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
* MM_30476 : Updated all imports as per instruction.
* MM_30476 : Shortening object chains by destructuring
* MM_30476 : Updated schema file structure
* MM_30476 : Prettifying @typings folder
* MM_30476 : Removing useless ids
* MM_30476 : Prettify imports for decorators
* MM_30476 : ADDED documentations and lazy queries to Channel and Channel_Info
* MM_30476 : ADDED documentations for default schema
* MM_30476 : Documentation [ IN PROGRESS ]
- Following JSDoc syntax for single line comment
- Removed redundant fields in the 'membership' tables and left only the @relation records.
* MM_30476 : Documentations [ IN PROGRESS ]
* MM_30476 : Documentations [ IN PROGRESS ]
* MM_30476 : Documentations [ IN PROGRESS ]
* MM_30476 : Documentations [ IN PROGRESS]
Updated
1) my_team and team,
2) my_channel and channel,
to each have 1:1 relationship with one another
* MM_30476 : Updated all Typescript definitions
* MM_30476 :Updated @relation to @immutableRelation
* MM_30476 : Updated description for previous_post_id
* MM_30478 : Updated patch package for wdb module
* MM_30478: DB Manager [IN PROGRESS ]
* MM_30478: DB Manager [IN PROGRESS]
* MM_30478: DB Manager [IN PROGRESS]
* MM_30478 : DB Manager [IN PROGRESS]
* MM_30478 : Deleting .db file on iOS
* MM_30478: Successfully deleting .db files and directory on iOS side
* MM_30478 : Update definition for default/global
* MM_30478 : Updated all models
* MM_30478 : Doing a bit of house cleaning
* MM_30478: Record of new server connection added to default/servers db
* TS Definitely Typed Assignment issue is now FIXED
* MM_30478 : TS Definitely Typed Assignment \n Removed all the constructors but error still in editor tabs. But this time the app is not crashing
* MM_30478 : Attempt 1 [SUCCESSFUL]
* MM_30478 : Removing useDefineForClassFields
* MM_30478 : Retrieving the servers in a list + Improved the DB Manager and Babel config
* MM_30478 : Updated babel.config.js
* MM_30478 : Minor UI correction
* MM_30478 : Jest and Typescript configuration
* MM_30478 : A bit of housekeeping
* MM_30478 : Installed WDB on Android
* MM_30478 : Deletes new server record from default DB
* MM_30478 : Returns subset of server db instances
* MM_30478 : Code clean up
* MM_30478 : Code clean up on db manager
* MM_30478 : House keeping + Patch for WDB
* MM_30478 : Android - Saving & Deleting in FilesDir [COMPLETED]
* MM_30478 : Code clean up
* MM_30478 : Code clean up
* MM_30478 : Code clean up
* MM_30478 : Test successful on Android device
* MM_30478 : Rolling back change to jest.config.js
* MM_30478 : Updated test to test_integration
* MM_30478 : Fix imports
* MM_30478 : Refactored the manual testscript
* MM_30478 : Renamed database manager test file
* MM_30478 : Code clean up
* MM_30478 : Updated manual test file with a note.
* MM_30482 : DataOperator [ IN PROGRESS ]
* MM_30482 : DataOperator - setting up the factory [ IN PROGRESS ]
* MM_30482: Code refactoring
* MM_30482 : DataOperator - setting up the factory [ IN PROGRESS ]
* MM_30482 : DataOperator - code clean up [ IN PROGRESS ]
* MM_30482 : Minor code clean up
* MM_30478 : Fixed JEST issue with TS
* MM_30478 : Fixed JEST issue with TS
* MM_30478 : Fixed JEST issue with TS
* MM_30478 : Implementing JEST test cases
* MM_30478 : Implementing JEST last test cases
* MM_30478 : Jest fixing ts errors
* MM_30478 : Database Manager Jest testing [ IN PROGRESS ]
* MM_30482 - Fixing DataOperator [ IN PROGRESS ]
* MM_30482 : Code clean up
* MM_30482 - Creates multiple records [ IN PROGRESS ]
* MM_30482 - Creates multiple records [ IN PROGRESS ]
* MM_30482 : Update operation [ COMPLETED ]
* MM_30482 : Code clean up
* MM_30482 : Updated TS for Data Operator
* Update mobile v2 detox deps
* MM_30482 : Added factories for all isolated tables
* MM_30482 : Refactored TS
* MM_30482 : Refactored base factory
* MM_30482 : Updated JSDoc for operateBaseRecord - Delete CASE
* MM_30482 : Implementing test for Data Operator
* MM_30482 : Completed tests for all isolated tables
* MM_30482 : Renamed entity_factory into operators
* MM_30482 : Fix all imports
* MM_30482 : Update multiple records
* MM_30482 : Edge case for existing records ( update instead of create )
* MM_30482 : Edge case - create instead of update
* MM_30482 : Code clean up
* MM_30482 : Code clean up
* MM_30482 : Code clean up
* MM_30482 : Code clean up
* Update app/database/admin/data_operator/operators.ts
Co-authored-by: Joseph Baylon <joseph.baylon@mattermost.com>
* Update app/database/admin/data_operator/operators.ts
Co-authored-by: Joseph Baylon <joseph.baylon@mattermost.com>
* Update app/database/admin/data_operator/operators.ts
Co-authored-by: Joseph Baylon <joseph.baylon@mattermost.com>
* MM_30482 : Imposing usage of correct table name for isolated entities
* MM_30482 : Code improvement as per Joseph reviews
* MM_30482 : Updated tests to validate choice of operator service wrt tableName
* MM_30482 : Updated PR as per suggestions
* MM_30482 : Updated comments to follow jsdoc conventions
* MM_33223 : Renamed DBInstance to DatabaseInstance
* MM_33223 : ADDED Prettier
* MM_33223 - Prettier formatting
* MM_33223 : Prettier formatting
* MM_33223 - Post section [ in progress ]
* MM_33223 : PostsInThread [99% completed ]
* MM_33223: Reaction entity completed
* MM_33223: Added Reaction to the Post
* MM_33223 : Refactored reactions utils
* MM_33223 : Added previous post id to all posts
* MM_33223 : Added File Metadata
* MM_33223 : Code clean up
* MM_33223 : Added PostMetadata
* MM_33223 : Added Draft
* MM_33223 - Removed Prettier
* MM_33223 - Undo files changes due to Prettier
* MM_33223 : Making use of MM eslint plugins
* MM_33223 : PostsInChannel [ IN PROGRESS ]
* MM_33223 : Including update_at in Post schema
* MM_33223: Code clean up
* MM_33223: Code clean up
* MM_33223 : Code clean up
* MM_33223: Testing Reaction [IN PROGRESS]
* MM_33223 : Updated typings for RawCustomEmoji in Reactions
* MM_33223 : Refactored DataOperator test
* MM_33223 : Jest - handleReactions - Completed
* MM_33223 : Jest - HandleDraft - Completed
* MM_33223 : Jest - HandleFiles - Completed
* MM_33223 : Refactored DataOperator-PostMetadata
* MM_33223 : Jest - HandlePostMetadata - Completed
* MM_33223 : Refactored posts into ordered and unordered
* MM_33223 : Refactoring + Jest Utils [ IN PROGRESS ]
* MM_33223 - Jest Utils - Completed
* MM_33223 : Jest - Remaining operators - Completed
* MM_33223 : Jest - Handler PostsInThread - Completed
* MM_33223 : Jest - HandlePostsInChannel - Completed
* MM_33223 : Refactored DataOperator class
* MM_33223 : DataOperator test clean up
* MM_33223 : DataOperator code clean up
* MM_33223 : Jest - HandlePosts - Completed
* MM_33223: JSDoc - Operators - Completed
* MM_33223 : Refactoring file types.ts
* MM_33223 : Refactored import statements
* MM_33223 : Added @database alias
* MM_33223 : Added missing JSDoc
* MM_33223 : Minor code clean up
* MM_33223 : Lint fixed
* MM_33223 : Disable eslint rules for Notification
* MM_33223 : Disable eslint rule for screens
* Update app/database/admin/data_operator/index.ts
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
* Apply suggestions from code review
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
* Apply suggestions from code review
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
* MM_33223 : Update data_operatator as per suggestion
* Update app/database/admin/data_operator/index.ts
* MM_33223 : Removed OptType as the operator can do without it.
* MM_33223 : Code correction after review
* MM_33223 : Refactored Data Operator following reviews
* MM_33223 : Including a wrapper to DataOperator
* MM_33223 : Completing tests for wrapper
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Joseph Baylon <joseph.baylon@mattermost.com>
Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
545 lines
18 KiB
TypeScript
545 lines
18 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
import {Q} from '@nozbe/watermelondb';
|
|
|
|
import {MM_TABLES} from '@constants/database';
|
|
import DatabaseManager from '@database/admin/database_manager';
|
|
import DataOperator from '@database/admin/data_operator';
|
|
import App from '@typings/database/app';
|
|
import {DatabaseType, IsolatedEntities} from '@typings/database/enums';
|
|
|
|
import {
|
|
operateAppRecord,
|
|
operateCustomEmojiRecord,
|
|
operateDraftRecord,
|
|
operateFileRecord,
|
|
operateGlobalRecord,
|
|
operatePostInThreadRecord,
|
|
operatePostMetadataRecord,
|
|
operatePostRecord,
|
|
operatePostsInChannelRecord,
|
|
operateReactionRecord,
|
|
operateRoleRecord,
|
|
operateServersRecord,
|
|
operateSystemRecord,
|
|
operateTermsOfServiceRecord,
|
|
} from './index';
|
|
|
|
jest.mock('@database/admin/database_manager');
|
|
|
|
const {APP} = MM_TABLES.DEFAULT;
|
|
|
|
describe('*** DataOperator: Operators tests ***', () => {
|
|
const createConnection = async (setActive = false) => {
|
|
const dbName = 'server_schema_connection';
|
|
const serverUrl = 'https://appv2.mattermost.com';
|
|
const database = await DatabaseManager.createDatabaseConnection({
|
|
shouldAddToDefaultDatabase: true,
|
|
configs: {
|
|
actionsEnabled: true,
|
|
dbName,
|
|
dbType: DatabaseType.SERVER,
|
|
serverUrl,
|
|
},
|
|
});
|
|
|
|
if (setActive) {
|
|
await DatabaseManager.setActiveServerDatabase({
|
|
displayName: dbName,
|
|
serverUrl,
|
|
});
|
|
}
|
|
|
|
return database;
|
|
};
|
|
|
|
it('=> operateAppRecord: should return an array of type App', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await DatabaseManager.getDefaultDatabase();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateAppRecord({
|
|
database: database!,
|
|
value: {
|
|
buildNumber: 'build-7',
|
|
createdAt: 1,
|
|
id: 'id-18',
|
|
versionNumber: 'v-1',
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('App');
|
|
});
|
|
|
|
it('=> operateGlobalRecord: should return an array of type Global', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await DatabaseManager.getDefaultDatabase();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateGlobalRecord({
|
|
database: database!,
|
|
value: {id: 'g-1', name: 'g-n1', value: 'g-v1'},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Global');
|
|
});
|
|
|
|
it('=> operateServersRecord: should return an array of type Servers', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await DatabaseManager.getDefaultDatabase();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateServersRecord({
|
|
database: database!,
|
|
value: {
|
|
dbPath: 'mm-server',
|
|
displayName: 's-displayName',
|
|
id: 's-1',
|
|
mentionCount: 1,
|
|
unreadCount: 0,
|
|
url: 'https://community.mattermost.com',
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Servers');
|
|
});
|
|
|
|
it('=> operateCustomEmojiRecord: should return an array of type CustomEmoji', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateCustomEmojiRecord({
|
|
database: database!,
|
|
value: {id: 'emo-1', name: 'emoji'},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('CustomEmoji');
|
|
});
|
|
|
|
it('=> operateRoleRecord: should return an array of type Role', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateRoleRecord({
|
|
database: database!,
|
|
value: {id: 'role-1', name: 'role-name-1', permissions: []},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Role');
|
|
});
|
|
|
|
it('=> operateSystemRecord: should return an array of type System', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateSystemRecord({
|
|
database: database!,
|
|
value: {id: 'system-1', name: 'system-name-1', value: 'system'},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('System');
|
|
});
|
|
|
|
it('=> operateTermsOfServiceRecord: should return an array of type TermsOfService', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateTermsOfServiceRecord({
|
|
database: database!,
|
|
value: {id: 'system-1', acceptedAt: 1},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch(
|
|
'TermsOfService',
|
|
);
|
|
});
|
|
|
|
it('=> should create a record in the App table in the default database', async () => {
|
|
expect.assertions(2);
|
|
|
|
// Creates a record in the App table
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-1',
|
|
createdAt: 1,
|
|
id: 'id-1',
|
|
versionNumber: 'version-1',
|
|
},
|
|
],
|
|
});
|
|
|
|
// Do a query and find out if the value has been registered in the App table of the default database
|
|
const connection = await DatabaseManager.getDefaultDatabase();
|
|
expect(connection).toBeTruthy();
|
|
|
|
const records = (await connection!.collections.
|
|
get(APP).
|
|
query(Q.where('id', 'id-1')).
|
|
fetch()) as App[];
|
|
|
|
// We should expect to have a record returned as dictated by our query
|
|
expect(records.length).toBe(1);
|
|
});
|
|
|
|
it('=> should create several records in the App table in the default database', async () => {
|
|
expect.assertions(2);
|
|
|
|
// Creates a record in the App table
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-10',
|
|
createdAt: 1,
|
|
id: 'id-10',
|
|
versionNumber: 'version-10',
|
|
},
|
|
{
|
|
buildNumber: 'build-11',
|
|
createdAt: 1,
|
|
id: 'id-11',
|
|
versionNumber: 'version-11',
|
|
},
|
|
{
|
|
buildNumber: 'build-12',
|
|
createdAt: 1,
|
|
id: 'id-12',
|
|
versionNumber: 'version-12',
|
|
},
|
|
{
|
|
buildNumber: 'build-13',
|
|
createdAt: 1,
|
|
id: 'id-13',
|
|
versionNumber: 'version-13',
|
|
},
|
|
],
|
|
});
|
|
|
|
// Do a query and find out if the value has been registered in the App table of the default database
|
|
const defaultDB = await DatabaseManager.getDefaultDatabase();
|
|
expect(defaultDB).toBeTruthy();
|
|
|
|
const records = (await defaultDB!.collections.
|
|
get(APP).
|
|
query(Q.where('id', Q.oneOf(['id-10', 'id-11', 'id-12', 'id-13']))).
|
|
fetch()) as App[];
|
|
|
|
// We should expect to have 4 records created
|
|
expect(records.length).toBe(4);
|
|
});
|
|
|
|
it('=> should update a record in the App table in the default database', async () => {
|
|
expect.assertions(3);
|
|
|
|
const defaultDB = await DatabaseManager.getDefaultDatabase();
|
|
expect(defaultDB).toBeTruthy();
|
|
|
|
// Update record having id 'id-1'
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-13-13',
|
|
createdAt: 1,
|
|
id: 'id-1',
|
|
versionNumber: 'version-1',
|
|
},
|
|
],
|
|
});
|
|
|
|
const records = (await defaultDB!.collections.
|
|
get(APP).
|
|
query(Q.where('id', 'id-1')).
|
|
fetch()) as App[];
|
|
expect(records.length).toBeGreaterThan(0);
|
|
|
|
// Verify if the buildNumber for this record has been updated
|
|
expect(records[0].buildNumber).toMatch('build-13-13');
|
|
});
|
|
|
|
it('=> should update several records in the App table in the default database', async () => {
|
|
expect.assertions(4);
|
|
|
|
const defaultDB = await DatabaseManager.getDefaultDatabase();
|
|
expect(defaultDB).toBeTruthy();
|
|
|
|
// Update records having id 'id-10' and 'id-11'
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-10x',
|
|
createdAt: 1,
|
|
id: 'id-10',
|
|
versionNumber: 'version-10',
|
|
},
|
|
{
|
|
buildNumber: 'build-11y',
|
|
createdAt: 1,
|
|
id: 'id-11',
|
|
versionNumber: 'version-11',
|
|
},
|
|
],
|
|
});
|
|
|
|
const records = (await defaultDB!.collections.
|
|
get(APP).
|
|
query(Q.where('id', Q.oneOf(['id-10', 'id-11']))).
|
|
fetch()) as App[];
|
|
expect(records.length).toBe(2);
|
|
|
|
// Verify if the buildNumber for those two record has been updated
|
|
expect(records[0].buildNumber).toMatch('build-10x');
|
|
expect(records[1].buildNumber).toMatch('build-11y');
|
|
});
|
|
|
|
it('=> [EDGE CASE] should UPDATE instead of CREATE record for existing id', async () => {
|
|
expect.assertions(3);
|
|
|
|
const defaultDB = await DatabaseManager.getDefaultDatabase();
|
|
expect(defaultDB).toBeTruthy();
|
|
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-10x',
|
|
createdAt: 1,
|
|
id: 'id-10',
|
|
versionNumber: 'version-10',
|
|
},
|
|
{
|
|
buildNumber: 'build-11x',
|
|
createdAt: 1,
|
|
id: 'id-11',
|
|
versionNumber: 'version-11',
|
|
},
|
|
],
|
|
});
|
|
|
|
const records = (await defaultDB!.collections.
|
|
get(APP).
|
|
query(Q.where('id', Q.oneOf(['id-10', 'id-11']))).
|
|
fetch()) as App[];
|
|
|
|
// Verify if the buildNumber for those two record has been updated
|
|
expect(records[0].buildNumber).toMatch('build-10x');
|
|
expect(records[1].buildNumber).toMatch('build-11x');
|
|
});
|
|
|
|
it('=> [EDGE CASE] should CREATE instead of UPDATE record for non-existing id', async () => {
|
|
expect.assertions(3);
|
|
|
|
const defaultDB = await DatabaseManager.getDefaultDatabase();
|
|
expect(defaultDB).toBeTruthy();
|
|
|
|
// id-15 and id-16 do not exist but yet the optType is UPDATE. The operator should then prepareCreate the records instead of prepareUpdate
|
|
await DataOperator.handleIsolatedEntity({
|
|
tableName: IsolatedEntities.APP,
|
|
values: [
|
|
{
|
|
buildNumber: 'build-10x',
|
|
createdAt: 1,
|
|
id: 'id-15',
|
|
versionNumber: 'version-10',
|
|
},
|
|
{
|
|
buildNumber: 'build-11x',
|
|
createdAt: 1,
|
|
id: 'id-16',
|
|
versionNumber: 'version-11',
|
|
},
|
|
],
|
|
});
|
|
|
|
const records = (await defaultDB!.collections.
|
|
get(APP).
|
|
query(Q.where('id', Q.oneOf(['id-15', 'id-16']))).
|
|
fetch()) as App[];
|
|
|
|
// Verify if the buildNumber for those two record has been created
|
|
expect(records[0].buildNumber).toMatch('build-10x');
|
|
expect(records[1].buildNumber).toMatch('build-11x');
|
|
});
|
|
|
|
it('=> operatePostRecord: should return an array of type Post', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operatePostRecord({
|
|
database: database!,
|
|
value: {
|
|
id: '8swgtrrdiff89jnsiwiip3y1eoe',
|
|
create_at: 1596032651748,
|
|
update_at: 1596032651748,
|
|
edit_at: 0,
|
|
delete_at: 0,
|
|
is_pinned: false,
|
|
user_id: 'q3mzxua9zjfczqakxdkowc6u6yy',
|
|
channel_id: 'xxoq1p6bqg7dkxb3kj1mcjoungw',
|
|
root_id: 'ps81iqbesfby8jayz7owg4yypoo',
|
|
parent_id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
original_id: '',
|
|
message: 'Testing operator post',
|
|
type: '',
|
|
props: {},
|
|
hashtags: '',
|
|
pending_post_id: '',
|
|
reply_count: 4,
|
|
last_reply_at: 0,
|
|
participants: null,
|
|
metadata: {},
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Post');
|
|
});
|
|
|
|
it('=> operatePostInThreadRecord: should return an array of type PostsInThread', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operatePostInThreadRecord({
|
|
database: database!,
|
|
value: {
|
|
id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
post_id: '8swgtrrdiff89jnsiwiip3y1eoe',
|
|
earliest: 1596032651748,
|
|
latest: 1597032651748,
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('PostsInThread');
|
|
});
|
|
|
|
it('=> operateReactionRecord: should return an array of type Reaction', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateReactionRecord({
|
|
database: database!,
|
|
value: {
|
|
id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
user_id: 'q3mzxua9zjfczqakxdkowc6u6yy',
|
|
post_id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
emoji_name: 'thumbsup',
|
|
create_at: 1596032651748,
|
|
update_at: 1608253011321,
|
|
delete_at: 0,
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Reaction');
|
|
});
|
|
|
|
it('=> operateFileRecord: should return an array of type File', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateFileRecord({
|
|
database: database!,
|
|
value: {
|
|
post_id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
name: 'test_file',
|
|
extension: '.jpg',
|
|
size: 1000,
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('File');
|
|
});
|
|
|
|
it('=> operatePostMetadataRecord: should return an array of type PostMetadata', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operatePostMetadataRecord({
|
|
database: database!,
|
|
value: {
|
|
id: 'ps81i4yypoo',
|
|
data: {},
|
|
postId: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
type: 'opengraph',
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('PostMetadata');
|
|
});
|
|
|
|
it('=> operateDraftRecord: should return an array of type Draft', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operateDraftRecord({
|
|
database: database!,
|
|
value: {
|
|
id: 'ps81i4yypoo',
|
|
root_id: 'ps81iqbddesfby8jayz7owg4yypoo',
|
|
message: 'draft message',
|
|
channel_id: 'channel_idp23232e',
|
|
files: [],
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('Draft');
|
|
});
|
|
|
|
it('=> operatePostsInChannelRecord: should return an array of type PostsInChannel', async () => {
|
|
expect.assertions(3);
|
|
|
|
const database = await createConnection();
|
|
expect(database).toBeTruthy();
|
|
|
|
const preparedRecords = await operatePostsInChannelRecord({
|
|
database: database!,
|
|
value: {
|
|
id: 'ps81i4yypoo',
|
|
channel_id: 'channel_idp23232e',
|
|
earliest: 1608253011321,
|
|
latest: 1609253011321,
|
|
},
|
|
});
|
|
|
|
expect(preparedRecords).toBeTruthy();
|
|
expect(preparedRecords!.collection.modelClass.name).toMatch('PostsInChannel');
|
|
});
|
|
});
|