Skip to content

Commit

Permalink
fix: test fixes & pr comments
Browse files Browse the repository at this point in the history
  • Loading branch information
EladBezalel committed Dec 11, 2023
1 parent a7eb41b commit dd48c25
Show file tree
Hide file tree
Showing 6 changed files with 35 additions and 108 deletions.
14 changes: 7 additions & 7 deletions libs/core/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,13 @@ const affected = await trueAffected({

### **Options**

| Option | Type | Description | Default |
| -------------- | ----------- | ------------------------------------------------------------ | ------------- |
| `rootTsConfig` | `string` | The path to the root tsconfig file | |
| `projects` | `Project[]` | An array of projects to check | |
| `cwd` | `string` | The current working directory | |
| `base` | `string` | The base branch to compare against | `origin/main` |
| `includeFiles` | `string[]` | Glob patterns to include (relative to projects' source root) | |
| Option | Type | Description | Default |
| -------------- | ----------------------- | ------------------------------------------------------------ | ----------------- |
| `rootTsConfig` | `string` | The path to the root tsconfig file | |
| `projects` | `Project[]` | An array of projects to check | |
| `cwd` | `string` | The current working directory | |
| `base` | `string` | The base branch to compare against | `origin/main` |
| `include` | `(string \| Regexp)[]` | Glob patterns to include (relative to projects' source root) | spec & test files |

> `rootTsConfig` - The path to the root tsconfig file, should include the `paths` prop with all projects mapping so `ts-morph` can find the references.
Expand Down
83 changes: 4 additions & 79 deletions libs/core/src/true-affected.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -165,77 +165,6 @@ describe('trueAffected', () => {
expect(affected).toEqual(['proj1', 'proj3']);
});

it('should include test files by suffixes', async () => {
jest.spyOn(git, 'getChangedFiles').mockReturnValue([
{
filePath: 'proj1/index._test_.ts',
changedLines: [6],
},
]);

const affected = await trueAffected({
cwd,
base: 'main',
rootTsConfig: 'tsconfig.json',
projects: [
{
name: 'proj1',
sourceRoot: 'proj1/',
tsConfig: 'proj1/tsconfig.json',
},
{
name: 'proj2',
sourceRoot: 'proj2/',
tsConfig: 'proj2/tsconfig.json',
},
{
name: 'proj3',
sourceRoot: 'proj3/',
tsConfig: 'proj3/tsconfig.json',
implicitDependencies: ['proj1'],
},
],
testSuffixes: ['_test_'],
});

expect(affected).toEqual(['proj1', 'proj3']);
});

it('should default test files suffixes to spec and test', async () => {
jest.spyOn(git, 'getChangedFiles').mockReturnValue([
{
filePath: 'proj1/index.spec.ts',
changedLines: [6],
},
]);

const affected = await trueAffected({
cwd,
base: 'main',
rootTsConfig: 'tsconfig.json',
projects: [
{
name: 'proj1',
sourceRoot: 'proj1/',
tsConfig: 'proj1/tsconfig.json',
},
{
name: 'proj2',
sourceRoot: 'proj2/',
tsConfig: 'proj2/tsconfig.json',
},
{
name: 'proj3',
sourceRoot: 'proj3/',
tsConfig: 'proj3/tsconfig.json',
implicitDependencies: ['proj1'],
},
],
});

expect(affected).toEqual(['proj1', 'proj3']);
});

it('should ignore files that are not in projects files', async () => {
jest.spyOn(git, 'getChangedFiles').mockReturnValue([
{
Expand Down Expand Up @@ -381,16 +310,12 @@ describe('trueAffected', () => {

it.each([
['regular path', ['package.json'], ['proj3']],
['glob path', ['**/package.json'], ['proj3']],
[
'multiple paths',
['package.json', '**/jest.config.js'],
['proj2', 'proj3'],
],
['regexp path', [/\.spec\.ts$/], ['proj1']],
['multiple paths', ['package.json', /\.spec\.ts$/], ['proj1', 'proj3']],
])('should include files with %s', async (title, filePatterns, expected) => {
jest.spyOn(git, 'getChangedFiles').mockReturnValue([
{
filePath: 'proj2/jest.config.js',
filePath: 'proj1/test.spec.ts',
changedLines: [1],
},
{
Expand Down Expand Up @@ -420,7 +345,7 @@ describe('trueAffected', () => {
tsConfig: 'proj3/tsconfig.json',
},
],
includeFiles: filePatterns,
include: filePatterns,
});

expect(affected).toEqual(expected);
Expand Down
37 changes: 20 additions & 17 deletions libs/core/src/true-affected.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,14 @@ const ignoredRootNodeTypes = [
SyntaxKind.IfStatement,
];

export const DEFAULT_INCLUDE_TEST_FILES = /\.(spec|test)\.(ts|js)x?/;

export const trueAffected = async ({
cwd,
rootTsConfig,
base = 'origin/main',
projects,
includeFiles = [],
testSuffixes = ['spec', 'test'],
include = [DEFAULT_INCLUDE_TEST_FILES],
}: TrueAffected) => {
const project = new Project({
compilerOptions: {
Expand Down Expand Up @@ -58,26 +59,21 @@ export const trueAffected = async ({
join(resolve(cwd, sourceRoot), '**/*.{ts,js}')
);
}

project.addSourceFilesAtPaths(
includeFiles.map((path) => `${resolve(cwd, sourceRoot)}/${path}`)
);
}
);

const sourceChangedFiles: GetChangedFiles[] = getChangedFiles({
const changedFiles = getChangedFiles({
base,
cwd,
}).filter(
});

const sourceChangedFiles: GetChangedFiles[] = changedFiles.filter(
({ filePath }) => project.getSourceFile(resolve(cwd, filePath)) != null
);

const ignoredPaths = ['./node_modules', './dist', './.git'];

const nonSourceChangedFiles: GetChangedFiles[] = getChangedFiles({
base,
cwd,
})
const nonSourceChangedFiles: GetChangedFiles[] = changedFiles
.filter(
({ filePath }) =>
!filePath.match(/.*\.(ts|js)x?$/g) &&
Expand All @@ -87,16 +83,23 @@ export const trueAffected = async ({
findNonSourceAffectedFiles(cwd, changedFilePath, ignoredPaths)
);

const changedFiles = [...sourceChangedFiles, ...nonSourceChangedFiles];
const filteredChangedFiles = [
...sourceChangedFiles,
...nonSourceChangedFiles,
];

const changedTestFilesPackages = changedFiles
const changedIncludedFilesPackages = changedFiles
.filter(({ filePath }) =>
new RegExp(`.*\\.(${testSuffixes.join('|')})\\.(ts|js)x?$`).test(filePath)
include.some((file) =>
typeof file === 'string'
? filePath.endsWith(file)
: filePath.match(file)
)
)
.map(({ filePath }) => getPackageNameByPath(filePath, projects))
.filter((v): v is string => v != null);

const affectedPackages = new Set<string>(changedTestFilesPackages);
const affectedPackages = new Set<string>(changedIncludedFilesPackages);
const visitedIdentifiers = new Map<string, string[]>();

const findReferencesLibs = (node: Node<ts.Node>) => {
Expand Down Expand Up @@ -134,7 +137,7 @@ export const trueAffected = async ({
});
};

changedFiles.forEach(({ filePath, changedLines }) => {
filteredChangedFiles.forEach(({ filePath, changedLines }) => {
const sourceFile = project.getSourceFile(resolve(cwd, filePath));

if (sourceFile == null) return;
Expand Down
3 changes: 1 addition & 2 deletions libs/core/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,5 @@ export interface TrueAffected {
rootTsConfig?: string;
base?: string;
projects: TrueAffectedProject[];
includeFiles?: string[];
testSuffixes?: string[];
include?: (string | RegExp)[];
}
2 changes: 1 addition & 1 deletion libs/nx/src/cli.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ describe('cli', () => {
rootTsConfig: 'tsconfig.base.json',
base: 'origin/main',
projects: [],
includeFiles: [],
include: [],
});
});

Expand Down
4 changes: 2 additions & 2 deletions libs/nx/src/cli.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { spawn } from 'node:child_process';
import { CommandModule } from 'yargs';
import { hideBin } from 'yargs/helpers';
import yargs from 'yargs/yargs';
import { trueAffected } from '@traf/core';
import { DEFAULT_INCLUDE_TEST_FILES, trueAffected } from '@traf/core';
import { getNxTrueAffectedProjects } from './nx';

const color = '#ff0083';
Expand Down Expand Up @@ -43,7 +43,7 @@ export const affectedAction = async ({
rootTsConfig: tsConfigFilePath,
base,
projects,
includeFiles,
include: [...includeFiles, DEFAULT_INCLUDE_TEST_FILES],
});

if (json) {
Expand Down

0 comments on commit dd48c25

Please sign in to comment.