Skip to content

Commit

Permalink
fix(core): fix handling of simple dependsOn target string
Browse files Browse the repository at this point in the history
closes nrwl#16931
- if a project has a `dependsOn` string with only a target that has the same
  name as another project, it is now treated correctly as a reference to
  a target in the same project
  • Loading branch information
acburdine committed May 11, 2023
1 parent 09525e8 commit 195165e
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 0 deletions.
19 changes: 19 additions & 0 deletions packages/nx/src/tasks-runner/utils.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -410,6 +410,25 @@ describe('utils', () => {
});
});

it('should assume target of self if simple target also matches project name', () => {
const result = expandDependencyConfigSyntaxSugar('build', {
dependencies: {},
nodes: {
build: {
name: 'build',
type: 'lib',
data: {
root: 'libs/build',
files: [],
},
},
},
});
expect(result).toEqual({
target: 'build',
});
});

it('should expand syntax for simple target names targetting dependencies', () => {
const result = expandDependencyConfigSyntaxSugar('^build', {
dependencies: {},
Expand Down
7 changes: 7 additions & 0 deletions packages/nx/src/tasks-runner/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,13 @@ export function expandDependencyConfigSyntaxSugar(

// Support for both `project:target` and `target:with:colons` syntax
const [maybeProject, ...segments] = splitByColons(targetString);

// if no additional segments are provided, then the string references
// a target of the same project
if (!segments.length) {
return { target: maybeProject };
}

return {
// Only the first segment could be a project. If it is, the rest is a target.
// If its not, then the whole targetString was a target with colons in its name.
Expand Down

0 comments on commit 195165e

Please sign in to comment.