-
Notifications
You must be signed in to change notification settings - Fork 539
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore: use nx commands #2493
chore: use nx commands #2493
Changes from 22 commits
22e58cd
d71f1cc
8fc8034
8c9ec9a
858fa77
e5c6bb7
97e7695
615401d
83781d0
95a4557
16122d5
f062d99
6acd051
b181935
6b5df30
6cec554
437637e
6aa6084
c7e6520
cef0847
7ab5103
59fb12c
3ad305c
ff866c0
530fdbb
07e998a
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,7 +10,6 @@ | |
"compile": "tsc -p .", | ||
"lint": "eslint . --ext .ts", | ||
"lint:fix": "eslint . --ext .ts --fix", | ||
"precompile": "tsc --version && lerna run version:update --scope @opentelemetry/resource-detector-alibaba-cloud --include-dependencies", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. note for reviewer: not necessary since |
||
"prewatch": "npm run precompile", | ||
"prepublishOnly": "npm run compile", | ||
"test": "nyc mocha 'test/**/*.test.ts'", | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
{ | ||
"tasksRunnerOptions": { | ||
"default": { | ||
"runner": "nx/tasks-runners/default", | ||
"options": { | ||
"cacheableOperations": [ | ||
"compile", | ||
"lint", | ||
"version:update" | ||
] | ||
} | ||
} | ||
}, | ||
"targetDefaults": { | ||
"compile": { | ||
"dependsOn": [ | ||
"version:update", | ||
"^compile" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. note for reviewer: this is the syntax to tell that dependencies within the monorepo should be compiled before compiling the current package |
||
], | ||
"inputs": [ | ||
"{projectRoot}/src", | ||
"{projectRoot}/test" | ||
], | ||
"outputs": [ | ||
"{projectRoot}/build" | ||
] | ||
}, | ||
"lint": { | ||
"inputs": [ | ||
"{projectRoot}/src", | ||
"{projectRoot}/test" | ||
] | ||
}, | ||
"version:update": { | ||
"inputs": [ | ||
"{projectRoot}/package.json" | ||
], | ||
"outputs": [ | ||
"{projectRoot}/src/version.ts" | ||
] | ||
} | ||
} | ||
} | ||
david-luna marked this conversation as resolved.
Show resolved
Hide resolved
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,25 +12,22 @@ | |
"main": "build/src/index.js", | ||
"types": "build/src/index.d.ts", | ||
"scripts": { | ||
"clean": "lerna run clean", | ||
"precompile": "tsc --version && npm run version:update", | ||
"version:update": "lerna run version:update", | ||
"compile": "lerna run compile", | ||
"prewatch": "npm run precompile", | ||
"test": "lerna run test", | ||
"test:ci:changed": "lerna run test --since origin/main", | ||
"test:browser": "lerna run test:browser --concurrency 1", | ||
"test-all-versions": "npm run --if-present --workspaces test-all-versions", | ||
"bump": "lerna publish", | ||
david-luna marked this conversation as resolved.
Show resolved
Hide resolved
|
||
"clean": "nx run-many -t clean", | ||
"version:update": "nx run-many -t version:update", | ||
"compile": "nx run-many -t compile", | ||
"test": "nx run-many -t test", | ||
"test:browser": "nx run-many -t test:browser", | ||
"test:ci:changed": "nx affected -t test --base=origin/main --head=HEAD", | ||
"test-all-versions": "nx run-many -t test-all-versions", | ||
"changelog": "lerna-changelog", | ||
"lint": "lerna run lint && npm run lint:deps && npm run lint:readme && npm run lint:markdown", | ||
"lint:fix": "lerna run lint:fix && npm run lint:markdown:fix", | ||
"lint": "nx run-many -t lint && npm run lint:readme && npm run lint:markdown", | ||
"lint:fix": "nx run-many -t lint:fix && npm run lint:markdown:fix", | ||
"lint:deps": "npx --yes [email protected] --dependencies --production --tags=-knipignore", | ||
"lint:examples": "eslint ./examples/**/*.js", | ||
"lint:examples:fix": "eslint ./examples/**/*.js --fix", | ||
"lint:markdown": "markdownlint-cli2 $(git ls-files '*.md')", | ||
"lint:markdown:fix": "markdownlint-cli2 --fix $(git ls-files '*.md')", | ||
"lint:readme": "lerna run lint:readme" | ||
"lint:readme": "nx run-many -t lint:readme" | ||
}, | ||
"keywords": [ | ||
"opentelemetry", | ||
|
@@ -57,6 +54,7 @@ | |
"lerna-changelog": "2.2.0", | ||
"markdownlint-cli2": "0.13.0", | ||
"minimatch": "^9.0.3", | ||
"nx": "15.9.7", | ||
"mocha": "^10.7.3", | ||
"prettier": "2.8.8", | ||
"process": "0.11.10", | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm a little scared of the "if
npm ci
andnpm run compile
layout is the same for all node versions". :)Have you done a basic check comparing two separate git clones that do those steps, one with node 16 and one with node 22, say?
node_modules/...
tree should be the same between versions -- otherwise the idea of package-lock.json is broken.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can do even another twist on this because:
ts-node
compilessrc
&tests
folders so "in theory" is not necessary to compile, just to have theversion.ts
file available@opentelemetry/resouce-detector-container
and these dependencies need to be build.Since the published packages are compiled using nodejs v16 maybe is better to have a "production" build as tests assets instead of a different build with each nodejs version (14, 18, 20, ...)?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't have them anymore AFAICT. The last was removed with grpc-cencus-binary-propagator (#2276) because it always built on macOS (it had pre-built binaries for linux+glibc so building sometimes does not happen based on which system one is using). I think if there was another one left we'd have noticed it by now as it tends to take a lot of time on install. 🙂
I think having the Node.js version matched with the published packages makes sense from a testing standpoint. This way we can preempt surprises if there are any. @david-luna would you mind putting a comment in the publish workflow and here that the versions should always be updated together? 🙂