### 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>
36 lines
825 B
TypeScript
36 lines
825 B
TypeScript
import * as fs from 'fs';
|
|
import * as path from 'path';
|
|
|
|
import { config } from 'dotenv';
|
|
config({ path: process.env.NODE_ENV === 'test' ? '.env.test' : '.env' });
|
|
|
|
export function generateFrontConfig(): void {
|
|
const configObject = {
|
|
window: {
|
|
_env_: {
|
|
REACT_APP_SERVER_BASE_URL: process.env.SERVER_URL,
|
|
},
|
|
},
|
|
};
|
|
|
|
const configString = `window._env_ = ${JSON.stringify(
|
|
configObject.window._env_,
|
|
null,
|
|
2,
|
|
)};`;
|
|
|
|
const distPath = path.join(__dirname, '../..', 'front');
|
|
const filePath = path.join(distPath, 'env-config.js');
|
|
|
|
if (!fs.existsSync(distPath)) {
|
|
fs.mkdirSync(distPath, { recursive: true });
|
|
}
|
|
|
|
if (
|
|
!fs.existsSync(filePath) ||
|
|
fs.readFileSync(filePath, 'utf8') !== configString
|
|
) {
|
|
fs.writeFileSync(filePath, configString, 'utf8');
|
|
}
|
|
}
|