forked from Ivasoft/mattermost-mobile
* MM_30476 : Added all isolated tables from the server schema * MM_30476 : Updated 'test' script in package.json * MM_30476 : ADDED team section of the server schema * MM_30476 : Apply suggestions from code review Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> * MM_30476 : Apply suggestions from code review Co-authored-by: Elias Nahum <nahumhbl@gmail.com> * MM_30476 : Updates to field name and description Co-authored-by: Elias Nahum <nahumhbl@gmail.com> Co-authored-by: Hossein <hahmadia@users.noreply.github.com> * MM_30476 : Updated my_team and team_search_history description * MM_30476 : Prefixing boolean fields with 'is' * MM_30476 : Updated channel.d.ts Co-authored-by: Hossein <hahmadia@users.noreply.github.com> Co-authored-by: Elias Nahum <nahumhbl@gmail.com> * MM_30476 : ADDED lazy queries to TeamMembership Two methods that will retrieve all users in a team and all the teams that a user is part of * MM_30476 : Updated descriptions for the associations * MM_30476 : Updated tests as server schema was updated * MM_30476 : Updated Team to have a 1:1 relationship with TeamChannelHistory * MM_30476 : Updated team_membership and user Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> Co-authored-by: Elias Nahum <nahumhbl@gmail.com> Co-authored-by: Hossein <hahmadia@users.noreply.github.com>
169 lines
7.3 KiB
TypeScript
169 lines
7.3 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {MM_TABLES} from '@constants/database';
|
|
|
|
import {serverSchema} from './index';
|
|
|
|
const {
|
|
CUSTOM_EMOJI,
|
|
MY_TEAM,
|
|
ROLE,
|
|
SLASH_COMMAND,
|
|
SYSTEM,
|
|
TERMS_OF_SERVICE,
|
|
TEAM,
|
|
TEAM_CHANNEL_HISTORY,
|
|
TEAM_MEMBERSHIP,
|
|
TEAM_SEARCH_HISTORY,
|
|
} = MM_TABLES.SERVER;
|
|
|
|
describe('*** Test schema for SERVER database ***', () => {
|
|
it('=> The SERVER SCHEMA should strictly match', () => {
|
|
expect(serverSchema).toEqual({
|
|
version: 1,
|
|
tables: {
|
|
[CUSTOM_EMOJI]: {
|
|
name: CUSTOM_EMOJI,
|
|
columns: {
|
|
name: {name: 'name', type: 'string'},
|
|
},
|
|
columnArray: [
|
|
{name: 'name', type: 'string'},
|
|
],
|
|
},
|
|
[MY_TEAM]: {
|
|
name: MY_TEAM,
|
|
columns: {
|
|
is_unread: {name: 'is_unread', type: 'boolean'},
|
|
mentions_count: {name: 'mentions_count', type: 'number'},
|
|
roles: {name: 'roles', type: 'string'},
|
|
team_id: {name: 'team_id', type: 'string', isIndexed: true},
|
|
},
|
|
columnArray: [
|
|
{name: 'is_unread', type: 'boolean'},
|
|
{name: 'mentions_count', type: 'number'},
|
|
{name: 'roles', type: 'string'},
|
|
{name: 'team_id', type: 'string', isIndexed: true},
|
|
],
|
|
},
|
|
[ROLE]: {
|
|
name: ROLE,
|
|
columns: {
|
|
name: {name: 'name', type: 'string'},
|
|
permissions: {name: 'permissions', type: 'string'},
|
|
},
|
|
columnArray: [
|
|
{name: 'name', type: 'string'},
|
|
{name: 'permissions', type: 'string'},
|
|
],
|
|
},
|
|
[SLASH_COMMAND]: {
|
|
name: SLASH_COMMAND,
|
|
columns: {
|
|
is_auto_complete: {name: 'is_auto_complete', type: 'boolean'},
|
|
description: {name: 'description', type: 'string'},
|
|
display_name: {name: 'display_name', type: 'string'},
|
|
hint: {name: 'hint', type: 'string'},
|
|
method: {name: 'method', type: 'string'},
|
|
team_id: {name: 'team_id', type: 'string', isIndexed: true},
|
|
token: {name: 'token', type: 'string'},
|
|
trigger: {name: 'trigger', type: 'string'},
|
|
},
|
|
columnArray: [
|
|
{name: 'is_auto_complete', type: 'boolean'},
|
|
{name: 'description', type: 'string'},
|
|
{name: 'display_name', type: 'string'},
|
|
{name: 'hint', type: 'string'},
|
|
{name: 'method', type: 'string'},
|
|
{name: 'team_id', type: 'string', isIndexed: true},
|
|
{name: 'token', type: 'string'},
|
|
{name: 'trigger', type: 'string'},
|
|
],
|
|
},
|
|
[SYSTEM]: {
|
|
name: SYSTEM,
|
|
columns: {
|
|
name: {name: 'name', type: 'string'},
|
|
value: {name: 'value', type: 'string'},
|
|
},
|
|
columnArray: [
|
|
{name: 'name', type: 'string'},
|
|
{name: 'value', type: 'string'},
|
|
],
|
|
},
|
|
[TEAM]: {
|
|
name: TEAM,
|
|
columns: {
|
|
is_allow_open_invite: {name: 'is_allow_open_invite', type: 'boolean'},
|
|
allowed_domains: {name: 'allowed_domains', type: 'string'},
|
|
description: {name: 'description', type: 'string'},
|
|
display_name: {name: 'display_name', type: 'string'},
|
|
is_group_constrained: {name: 'is_group_constrained', type: 'boolean'},
|
|
last_team_icon_updated_at: {name: 'last_team_icon_updated_at', type: 'number'},
|
|
name: {name: 'name', type: 'string'},
|
|
type: {name: 'type', type: 'string'},
|
|
},
|
|
columnArray: [
|
|
{name: 'is_allow_open_invite', type: 'boolean'},
|
|
{name: 'allowed_domains', type: 'string'},
|
|
{name: 'description', type: 'string'},
|
|
{name: 'display_name', type: 'string'},
|
|
{name: 'is_group_constrained', type: 'boolean'},
|
|
{name: 'last_team_icon_updated_at', type: 'number'},
|
|
{name: 'name', type: 'string'},
|
|
{name: 'type', type: 'string'},
|
|
],
|
|
},
|
|
[TEAM_CHANNEL_HISTORY]: {
|
|
name: TEAM_CHANNEL_HISTORY,
|
|
columns: {
|
|
channel_ids: {name: 'channel_ids', type: 'string'},
|
|
team_id: {name: 'team_id', type: 'string', isIndexed: true},
|
|
},
|
|
columnArray: [
|
|
{name: 'channel_ids', type: 'string'},
|
|
{name: 'team_id', type: 'string', isIndexed: true},
|
|
],
|
|
},
|
|
[TEAM_MEMBERSHIP]: {
|
|
name: TEAM_MEMBERSHIP,
|
|
columns: {
|
|
team_id: {name: 'team_id', type: 'string', isIndexed: true},
|
|
user_id: {name: 'user_id', type: 'string', isIndexed: true},
|
|
},
|
|
columnArray: [
|
|
{name: 'team_id', type: 'string', isIndexed: true},
|
|
{name: 'user_id', type: 'string', isIndexed: true},
|
|
],
|
|
},
|
|
[TEAM_SEARCH_HISTORY]: {
|
|
name: TEAM_SEARCH_HISTORY,
|
|
columns: {
|
|
created_at: {name: 'created_at', type: 'number'},
|
|
display_term: {name: 'display_term', type: 'string'},
|
|
team_id: {name: 'team_id', type: 'string', isIndexed: true},
|
|
term: {name: 'term', type: 'string'},
|
|
|
|
},
|
|
columnArray: [
|
|
{name: 'created_at', type: 'number'},
|
|
{name: 'display_term', type: 'string'},
|
|
{name: 'team_id', type: 'string', isIndexed: true},
|
|
{name: 'term', type: 'string'},
|
|
],
|
|
},
|
|
[TERMS_OF_SERVICE]: {
|
|
name: TERMS_OF_SERVICE,
|
|
columns: {
|
|
accepted_at: {name: 'accepted_at', type: 'number'},
|
|
},
|
|
columnArray: [
|
|
{name: 'accepted_at', type: 'number'},
|
|
],
|
|
},
|
|
},
|
|
});
|
|
});
|
|
});
|