mirror of
https://github.com/twentyhq/twenty.git
synced 2024-12-02 10:04:09 +03:00
eef7f1661d
### Summary This PR introduces several integration tests, a mix of manually written tests and those generated using the `generate-integration-tests` Python script located in the `scripts` folder. ### Tests Added: - **Authentication tests**: Validating login, registration, and token handling. - **FindMany queries**: Fetching multiple records for all existing entities that do not require input arguments. ### How the Integration Tests Work: - A `setupTest` function is called during the Jest test run. This function initializes a test instance of the application and exposes it on a dedicated port. - Since tests are executed in isolated workers, they do not have direct access to the in-memory app instance. Instead, the tests query the application through the exposed port. - A static accessToken is used, this one as a big expiration time so it will never expire (365 years) - The queries are executed, and the results are validated against expected outcomes. ### Current State and Next Steps: - These tests currently run using the existing development seed data. We plan to introduce more comprehensive test data using `faker` to improve coverage. - At the moment, the only mutation tests implemented are for authentication. Future updates should include broader mutation testing for other entities. --------- Co-authored-by: Charles Bochet <charles@twenty.com>
86 lines
2.8 KiB
TypeScript
86 lines
2.8 KiB
TypeScript
import request from 'supertest';
|
|
|
|
const client = request(`http://localhost:${APP_PORT}`);
|
|
|
|
describe('messageChannelsResolver (integration)', () => {
|
|
it('should find many messageChannels', () => {
|
|
const queryData = {
|
|
query: `
|
|
query messageChannels {
|
|
messageChannels {
|
|
edges {
|
|
node {
|
|
visibility
|
|
handle
|
|
type
|
|
isContactAutoCreationEnabled
|
|
contactAutoCreationPolicy
|
|
excludeNonProfessionalEmails
|
|
excludeGroupEmails
|
|
isSyncEnabled
|
|
syncCursor
|
|
syncedAt
|
|
syncStatus
|
|
syncStage
|
|
syncStageStartedAt
|
|
throttleFailureCount
|
|
id
|
|
createdAt
|
|
updatedAt
|
|
deletedAt
|
|
connectedAccountId
|
|
}
|
|
}
|
|
}
|
|
}
|
|
`,
|
|
};
|
|
|
|
return client
|
|
.post('/graphql')
|
|
.set('Authorization', `Bearer ${ACCESS_TOKEN}`)
|
|
.send(queryData)
|
|
.expect(200)
|
|
.expect((res) => {
|
|
expect(res.body.data).toBeDefined();
|
|
expect(res.body.errors).toBeUndefined();
|
|
})
|
|
.expect((res) => {
|
|
const data = res.body.data.messageChannels;
|
|
|
|
expect(data).toBeDefined();
|
|
expect(Array.isArray(data.edges)).toBe(true);
|
|
|
|
const edges = data.edges;
|
|
|
|
if (edges.length > 0) {
|
|
const messageChannels = edges[0].node;
|
|
|
|
expect(messageChannels).toHaveProperty('visibility');
|
|
expect(messageChannels).toHaveProperty('handle');
|
|
expect(messageChannels).toHaveProperty('type');
|
|
expect(messageChannels).toHaveProperty(
|
|
'isContactAutoCreationEnabled',
|
|
);
|
|
expect(messageChannels).toHaveProperty('contactAutoCreationPolicy');
|
|
expect(messageChannels).toHaveProperty(
|
|
'excludeNonProfessionalEmails',
|
|
);
|
|
expect(messageChannels).toHaveProperty('excludeGroupEmails');
|
|
expect(messageChannels).toHaveProperty('isSyncEnabled');
|
|
expect(messageChannels).toHaveProperty('syncCursor');
|
|
expect(messageChannels).toHaveProperty('syncedAt');
|
|
expect(messageChannels).toHaveProperty('syncStatus');
|
|
expect(messageChannels).toHaveProperty('syncStage');
|
|
expect(messageChannels).toHaveProperty('syncStageStartedAt');
|
|
expect(messageChannels).toHaveProperty('throttleFailureCount');
|
|
expect(messageChannels).toHaveProperty('id');
|
|
expect(messageChannels).toHaveProperty('createdAt');
|
|
expect(messageChannels).toHaveProperty('updatedAt');
|
|
expect(messageChannels).toHaveProperty('deletedAt');
|
|
expect(messageChannels).toHaveProperty('connectedAccountId');
|
|
}
|
|
});
|
|
});
|
|
});
|