-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: switch to using
package_json
for interacting with `package.js…
…on` (#466) This allows us to support all of the major javascript package managers by relying on the [`package_json`](https://github.com/shakacode/package_json) gem to handle running and generating commands for a particular package manager. Currently I'm making our template actually agnostic and have setup to test that is the case by running against the major package managers + Yarn PnP, though I expect after landing this we'll decide on a single package manager to use going forward and remove code that is needed for the other package managers.
- Loading branch information
Showing
17 changed files
with
302 additions
and
83 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -18,6 +18,13 @@ concurrency: | |
# should be granted per job as needed using a dedicated `permissions` block | ||
permissions: {} | ||
|
||
env: | ||
# reduces noise from npm install | ||
DISABLE_OPENCOLLECTIVE: true | ||
OPEN_SOURCE_CONTRIBUTOR: true | ||
NPM_CONFIG_FUND: false | ||
NPM_CONFIG_AUDIT: false | ||
|
||
jobs: | ||
audit_dependencies: | ||
permissions: | ||
|
@@ -29,6 +36,8 @@ jobs: | |
persist-credentials: false | ||
- name: Audit dependencies for security vulnerabilities | ||
uses: g-rath/check-with-osv-detector@main | ||
with: | ||
osv-detector-version: 0.13.0 | ||
test: | ||
permissions: | ||
contents: read | ||
|
@@ -70,6 +79,24 @@ jobs: | |
# how many fail) | ||
fail-fast: false | ||
matrix: | ||
js_package_manager: | ||
- name: npm | ||
installer: npm | ||
- name: yarn_berry | ||
installer: yarn | ||
linker: pnp | ||
- name: yarn_berry | ||
installer: yarn | ||
linker: node-modules | ||
- name: yarn_berry | ||
installer: yarn | ||
linker: pnpm | ||
- name: yarn_classic | ||
installer: yarn | ||
- name: pnpm | ||
installer: pnpm | ||
- name: bun | ||
installer: bun | ||
variant: | ||
- name: defaults | ||
config_path: 'ackama_rails_template.config.yml' | ||
|
@@ -131,6 +158,8 @@ jobs: | |
# this ensures that osv-detector is available for running bin/ci-run | ||
- name: Check dependencies for vulnerabilities (and setup osv-detector) | ||
uses: g-rath/check-with-osv-detector@main | ||
with: | ||
osv-detector-version: 0.13.0 | ||
|
||
# this ensures that actionlint is available for running bin/ci-run | ||
- name: Setup ActionLint | ||
|
@@ -142,9 +171,11 @@ jobs: | |
- name: Install NodeJS | ||
uses: actions/setup-node@v4 | ||
with: | ||
cache: 'yarn' | ||
node-version-file: '.node-version' | ||
|
||
- name: install package manager | ||
run: npm i -g ${{ matrix.js_package_manager.installer }} | ||
|
||
# We don't cache gems or JS packages because we are actually testing how | ||
# installation and setup works in this project so, while caching would | ||
# make CI faster, it might hide problems. | ||
|
@@ -161,6 +192,9 @@ jobs: | |
git config --global user.email "[email protected]" | ||
git config --global user.name "Your Name" | ||
# prettier-ignore | ||
- run: ./ci/bin/create-fake-js-package-managers ${{ matrix.js_package_manager.installer }} | ||
|
||
- name: Run CI script | ||
env: | ||
# Remember that your app name becomes a top-level constant in the | ||
|
@@ -173,4 +207,7 @@ jobs: | |
PGUSER: postgres | ||
PGPASSWORD: postgres | ||
PGHOST: localhost | ||
PACKAGE_JSON_FALLBACK_MANAGER: ${{ matrix.js_package_manager.name }} | ||
PACKAGE_JSON_YARN_BERRY_LINKER: | ||
${{ matrix.js_package_manager.linker }} | ||
run: ./ci/bin/build-and-test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
#!/usr/bin/env ruby | ||
|
||
# creates a set of fake JavaScript package managers in a temporary bin | ||
# directory for GitHub Actions, _excluding_ the one passed in as an | ||
# argument in order to assert that only that package manager is used | ||
|
||
require "fileutils" | ||
require "tmpdir" | ||
|
||
# setup the bin directory we want to use | ||
bin_dir = "tmp/fake-bin" | ||
|
||
if ENV["GITHUB_ACTIONS"] | ||
bin_dir = Dir.mktmpdir("rails-template-") | ||
|
||
puts "adding #{bin_dir} to GITHUB_PATH..." | ||
|
||
File.write(ENV.fetch("GITHUB_PATH"), "#{bin_dir}\n", mode: "a+") | ||
elsif system("direnv --version > /dev/null 2>&1") | ||
envrc_content = "PATH_add #{bin_dir}\n" | ||
|
||
if File.exist?(".envrc") && File.read(".envrc").include?(envrc_content) | ||
puts "'#{envrc_content.strip}' already exists in .envrc" | ||
else | ||
File.write(".envrc", envrc_content, mode: "a") | ||
puts "Added '#{envrc_content.strip}' to .envrc" | ||
end | ||
|
||
# ensure the .envrc is allowed | ||
system("direnv allow") | ||
end | ||
|
||
managers = %w[npm yarn pnpm bun] | ||
manager_in_use = ARGV[0] || "" | ||
|
||
if manager_in_use.empty? | ||
manager_in_use = ENV.fetch("PACKAGE_JSON_FALLBACK_MANAGER", "") | ||
.delete_suffix("_berry") | ||
.delete_suffix("_classic") | ||
end | ||
|
||
Dir.chdir(bin_dir) do | ||
managers.each do |manager| | ||
if manager == manager_in_use | ||
# ensure that the manager is not stubbed in case we've changed managers | ||
FileUtils.rm_f(manager) | ||
|
||
next | ||
end | ||
|
||
puts "creating #{bin_dir}/#{manager}..." | ||
File.write( | ||
manager, | ||
<<~CONTENTS | ||
#!/usr/bin/env node | ||
throw new Error("(#{manager}) this is not the package manager you're looking for..."); | ||
CONTENTS | ||
) | ||
File.chmod(0o755, manager) | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 1 addition & 1 deletion
2
variants/backend-base/lib/tasks/assets.rake → ...nts/backend-base/lib/tasks/assets.rake.tt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,5 @@ | ||
copy_file "variants/backend-base/lib/tasks/coverage.rake", "lib/tasks/coverage.rake" | ||
copy_file "variants/backend-base/lib/tasks/assets.rake", "lib/tasks/assets.rake" | ||
copy_file "variants/backend-base/lib/tasks/app.rake", "lib/tasks/app.rake" | ||
copy_file "variants/backend-base/lib/tasks/dev.rake", "lib/tasks/dev.rake" | ||
|
||
template "variants/backend-base/lib/tasks/assets.rake.tt", "lib/tasks/assets.rake", force: true |
Oops, something went wrong.