2023-07-27 19:48:40 +03:00
|
|
|
import { INestApplication } from '@nestjs/common';
|
|
|
|
|
|
|
|
import request from 'supertest';
|
|
|
|
|
2024-03-15 16:40:58 +03:00
|
|
|
import { JwtAuthGuard } from 'src/engine/guards/jwt.auth.guard';
|
2023-07-27 19:48:40 +03:00
|
|
|
|
|
|
|
import { createApp } from './utils/create-app';
|
|
|
|
|
|
|
|
describe('CompanyResolver (e2e)', () => {
|
|
|
|
let app: INestApplication;
|
|
|
|
let companyId: string | undefined;
|
|
|
|
|
|
|
|
const authGuardMock = { canActivate: (): any => true };
|
|
|
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
[app] = await createApp({
|
|
|
|
moduleBuilderHook: (moduleBuilder) =>
|
|
|
|
moduleBuilder.overrideGuard(JwtAuthGuard).useValue(authGuardMock),
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(async () => {
|
|
|
|
await app.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should create a company', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
mutation CreateOneCompany($data: CompanyCreateInput!) {
|
|
|
|
createOneCompany(data: $data) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
data: {
|
|
|
|
name: 'New Company',
|
|
|
|
domainName: 'new-company.com',
|
|
|
|
address: 'New Address',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const data = res.body.data.createOneCompany;
|
|
|
|
|
|
|
|
companyId = data.id;
|
|
|
|
|
|
|
|
expect(data).toBeDefined();
|
|
|
|
expect(data).toHaveProperty('id');
|
|
|
|
expect(data).toHaveProperty('name', 'New Company');
|
|
|
|
expect(data).toHaveProperty('domainName', 'new-company.com');
|
|
|
|
expect(data).toHaveProperty('address', 'New Address');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should find many companies', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
query FindManyCompany {
|
|
|
|
findManyCompany {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const data = res.body.data.findManyCompany;
|
chore: use Nx affected tasks in CI (#5110)
Closes #5097
- Uses "nx affected" to detect what projects need to be checked in the
current PR (for now, `ci-front` and `ci-server` workflows only).
- Caches results of certain tasks (`lint`, `typecheck`, `test`,
`storybook:build`) when a PR pipeline runs. The next runs of the same
PR's pipeline will then be able to reuse the PR's task cache to execute
tasks faster.
- Caches Yarn's cache folder to install dependencies faster in CI jobs.
- Rewrites the node modules cache/install steps as a custom, reusable
Github action.
- Distributes `ci-front` jobs with a "matrix" strategy.
- Sets common tasks config at the root `nx.json`. For instance, to
activate the `typecheck` task in a project, add `typecheck: {}` to its
`project.json` and it'll use the default config set in `nx.json` for the
`typecheck` task. Options can be overridden in each individual
`project.json` if needed.
- Adds "scope" tags to some projects: `scope:frontend`, `scope:backend`,
`scope:shared`. An eslint rule ensures that `scope:frontend` only
depends on `scope:frontent` or `scope:shared` projects, same for
`scope:backend`. These tags are used by `nx affected` to filter projects
by scope and generates different task cache keys according to the
requested scope.
- Enables checks for twenty-emails in the `ci-server` workflow.
2024-04-30 17:28:25 +03:00
|
|
|
|
2023-07-27 19:48:40 +03:00
|
|
|
expect(data).toBeDefined();
|
|
|
|
expect(Array.isArray(data)).toBe(true);
|
|
|
|
expect(data.length).toBeGreaterThan(0);
|
|
|
|
|
|
|
|
const company = data.find((c) => c.id === companyId);
|
chore: use Nx affected tasks in CI (#5110)
Closes #5097
- Uses "nx affected" to detect what projects need to be checked in the
current PR (for now, `ci-front` and `ci-server` workflows only).
- Caches results of certain tasks (`lint`, `typecheck`, `test`,
`storybook:build`) when a PR pipeline runs. The next runs of the same
PR's pipeline will then be able to reuse the PR's task cache to execute
tasks faster.
- Caches Yarn's cache folder to install dependencies faster in CI jobs.
- Rewrites the node modules cache/install steps as a custom, reusable
Github action.
- Distributes `ci-front` jobs with a "matrix" strategy.
- Sets common tasks config at the root `nx.json`. For instance, to
activate the `typecheck` task in a project, add `typecheck: {}` to its
`project.json` and it'll use the default config set in `nx.json` for the
`typecheck` task. Options can be overridden in each individual
`project.json` if needed.
- Adds "scope" tags to some projects: `scope:frontend`, `scope:backend`,
`scope:shared`. An eslint rule ensures that `scope:frontend` only
depends on `scope:frontent` or `scope:shared` projects, same for
`scope:backend`. These tags are used by `nx affected` to filter projects
by scope and generates different task cache keys according to the
requested scope.
- Enables checks for twenty-emails in the `ci-server` workflow.
2024-04-30 17:28:25 +03:00
|
|
|
|
2023-07-27 19:48:40 +03:00
|
|
|
expect(company).toBeDefined();
|
|
|
|
expect(company).toHaveProperty('id');
|
|
|
|
expect(company).toHaveProperty('name', 'New Company');
|
|
|
|
expect(company).toHaveProperty('domainName', 'new-company.com');
|
|
|
|
expect(company).toHaveProperty('address', 'New Address');
|
|
|
|
|
|
|
|
// Check if we have access to ressources outside of our workspace
|
|
|
|
const instagramCompany = data.find((c) => c.name === 'Instagram');
|
chore: use Nx affected tasks in CI (#5110)
Closes #5097
- Uses "nx affected" to detect what projects need to be checked in the
current PR (for now, `ci-front` and `ci-server` workflows only).
- Caches results of certain tasks (`lint`, `typecheck`, `test`,
`storybook:build`) when a PR pipeline runs. The next runs of the same
PR's pipeline will then be able to reuse the PR's task cache to execute
tasks faster.
- Caches Yarn's cache folder to install dependencies faster in CI jobs.
- Rewrites the node modules cache/install steps as a custom, reusable
Github action.
- Distributes `ci-front` jobs with a "matrix" strategy.
- Sets common tasks config at the root `nx.json`. For instance, to
activate the `typecheck` task in a project, add `typecheck: {}` to its
`project.json` and it'll use the default config set in `nx.json` for the
`typecheck` task. Options can be overridden in each individual
`project.json` if needed.
- Adds "scope" tags to some projects: `scope:frontend`, `scope:backend`,
`scope:shared`. An eslint rule ensures that `scope:frontend` only
depends on `scope:frontent` or `scope:shared` projects, same for
`scope:backend`. These tags are used by `nx affected` to filter projects
by scope and generates different task cache keys according to the
requested scope.
- Enables checks for twenty-emails in the `ci-server` workflow.
2024-04-30 17:28:25 +03:00
|
|
|
|
2023-07-27 19:48:40 +03:00
|
|
|
expect(instagramCompany).toBeUndefined();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should find unique company', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
query FindUniqueCompany($where: CompanyWhereUniqueInput!) {
|
|
|
|
findUniqueCompany(where: $where) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
where: {
|
|
|
|
id: companyId,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const data = res.body.data.findUniqueCompany;
|
|
|
|
|
|
|
|
expect(data).toBeDefined();
|
|
|
|
expect(data).toHaveProperty('id');
|
|
|
|
expect(data).toHaveProperty('name', 'New Company');
|
|
|
|
expect(data).toHaveProperty('domainName', 'new-company.com');
|
|
|
|
expect(data).toHaveProperty('address', 'New Address');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not find unique company (forbidden because outside workspace)', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
query FindUniqueCompany($where: CompanyWhereUniqueInput!) {
|
|
|
|
findUniqueCompany(where: $where) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
where: {
|
|
|
|
id: 'twenty-dev-a674fa6c-1455-4c57-afaf-dd5dc086361e',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const errors = res.body.errors;
|
|
|
|
const error = errors?.[0];
|
|
|
|
|
|
|
|
expect(error).toBeDefined();
|
2023-09-28 17:27:34 +03:00
|
|
|
expect(error.message).toBe('Forbidden resource');
|
2023-07-27 19:48:40 +03:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should update a company', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
mutation UpdateOneCompany($where: CompanyWhereUniqueInput!, $data: CompanyUpdateInput!) {
|
|
|
|
updateOneCompany(data: $data, where: $where) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
where: {
|
|
|
|
id: companyId,
|
|
|
|
},
|
|
|
|
data: {
|
|
|
|
name: 'Updated Company',
|
|
|
|
domainName: 'updated-company.com',
|
|
|
|
address: 'Updated Address',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const data = res.body.data.updateOneCompany;
|
|
|
|
|
|
|
|
expect(data).toBeDefined();
|
|
|
|
expect(data).toHaveProperty('id');
|
|
|
|
expect(data).toHaveProperty('name', 'Updated Company');
|
|
|
|
expect(data).toHaveProperty('domainName', 'updated-company.com');
|
|
|
|
expect(data).toHaveProperty('address', 'Updated Address');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not update a company (forbidden because outside workspace)', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
mutation UpdateOneCompany($where: CompanyWhereUniqueInput!, $data: CompanyUpdateInput!) {
|
|
|
|
updateOneCompany(data: $data, where: $where) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
domainName
|
|
|
|
address
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
where: {
|
|
|
|
id: 'twenty-dev-a674fa6c-1455-4c57-afaf-dd5dc086361e',
|
|
|
|
},
|
|
|
|
data: {
|
|
|
|
name: 'Updated Instagram',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const errors = res.body.errors;
|
|
|
|
const error = errors?.[0];
|
|
|
|
|
|
|
|
expect(error).toBeDefined();
|
2023-09-28 17:27:34 +03:00
|
|
|
expect(error.message).toBe('Forbidden resource');
|
2023-07-27 19:48:40 +03:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should delete a company', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
mutation DeleteManyCompany($ids: [String!]) {
|
|
|
|
deleteManyCompany(where: {id: {in: $ids}}) {
|
|
|
|
count
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
ids: [companyId],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const data = res.body.data.deleteManyCompany;
|
|
|
|
|
|
|
|
companyId = undefined;
|
|
|
|
|
|
|
|
expect(data).toBeDefined();
|
|
|
|
expect(data).toHaveProperty('count', 1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not delete a company (forbidden because outside workspace)', () => {
|
|
|
|
const queryData = {
|
|
|
|
query: `
|
|
|
|
mutation DeleteManyCompany($ids: [String!]) {
|
|
|
|
deleteManyCompany(where: {id: {in: $ids}}) {
|
|
|
|
count
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
variables: {
|
|
|
|
ids: ['twenty-dev-a674fa6c-1455-4c57-afaf-dd5dc086361e'],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return request(app.getHttpServer())
|
|
|
|
.post('/graphql')
|
|
|
|
.send(queryData)
|
|
|
|
.expect(200)
|
|
|
|
.expect((res) => {
|
|
|
|
const errors = res.body.errors;
|
|
|
|
const error = errors?.[0];
|
|
|
|
|
|
|
|
expect(error).toBeDefined();
|
2023-09-28 17:27:34 +03:00
|
|
|
expect(error.message).toBe('Forbidden resource');
|
2023-07-27 19:48:40 +03:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|