Skip to content

Commit

Permalink
test: test node packages
Browse files Browse the repository at this point in the history
  • Loading branch information
charislam committed Dec 6, 2024
1 parent dda2a52 commit 4faabe6
Show file tree
Hide file tree
Showing 4 changed files with 166 additions and 4 deletions.
160 changes: 160 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -197,3 +197,163 @@ jobs:
name: artifact-npm-binary-distributions
path: npm-binary-distributions/*/*.tgz
if-no-files-found: "error"

test-linux:
runs-on: ubuntu-latest
needs: [node, npm-distributions]
strategy:
fail-fast: false
matrix:
node-version: [18, 20, 22]
steps:
- uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
with:
node-version: ${{ matrix.node-version }}
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-npm-binary-distributions
path: ./npm-binary-distributions
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-pkg-node
path: ./node-pkg
- name: Create package.json
run: |
mkdir test
cd test
cat <<EOF > package.json
{
"name": "test",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"lint": "supa-mdx-lint --version"
},
"keywords": [],
"author": "",
"license": "ISC"
}
EOF
- name: Install test packages
working-directory: test
run: |
npm install ../npm-binary-distributions/linux-x64/*.tgz
npm install ../node-pkg/*.tgz
- name: Test lint script
working-directory: test
run: npm run lint

test-macos:
runs-on: macos-latest
needs: [node, npm-distributions]
strategy:
fail-fast: false
matrix:
node-version: [18, 20, 22]
steps:
- uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
with:
node-version: ${{ matrix.node-version }}
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-npm-binary-distributions
path: ./npm-binary-distributions
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-pkg-node
path: ./node-pkg
- name: Create package.json
run: |
mkdir test
cd test
cat <<EOF > package.json
{
"name": "test",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"lint": "supa-mdx-lint --version"
},
"keywords": [],
"author": "",
"license": "ISC"
}
EOF
- name: Install test packages
working-directory: test
run: |
npm install ../npm-binary-distributions/darwin/*.tgz
npm install ../node-pkg/*.tgz
- name: Test lint script
working-directory: test
run: npm run lint

test-windows:
runs-on: windows-latest
needs: [node, npm-distributions]
strategy:
fail-fast: false
matrix:
node-version: [18, 20, 22]
steps:
- uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af # v4.1.0
with:
node-version: ${{ matrix.node-version }}
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-npm-binary-distributions
path: ./npm-binary-distributions
- uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
name: artifact-pkg-node
path: ./node-pkg
- name: Create package.json
shell: pwsh
run: |
mkdir test
cd test
$json = @"
{
"name": "test",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"lint": "supa-mdx-lint --version"
},
"keywords": [],
"author": "",
"license": "ISC"
}
"@
$json | Out-File -FilePath package.json -Encoding utf8
- name: Unpack binary tarball
shell: pwsh
run: |
$tarballPath = Get-ChildItem -Path npm-binary-distributions\win32-x64\*.tgz | Select-Object -First 1
tar -xzf $tarballPath.FullName -C npm-binary-distributions\win32-x64
Get-ChildItem -Path npm-binary-distributions\win32-x64\package
- name: Install binary
run: |
cd test
npm install ..\npm-binary-distributions\win32-x64\package
- name: Unpack node-pkg tarball
shell: pwsh
run: |
$tarballPath = Get-ChildItem -Path node-pkg\*.tgz | Select-Object -First 1
mkdir -Path "test\node_modules\supa-mdx-lint-node-pkg" -Force
tar -xzf $tarballPath.FullName -C test\node_modules\supa-mdx-lint-node-pkg
- name: Install main package
run: |
cd test
npm install node_modules\supa-mdx-lint-node-pkg\package
- name: Test lint script
working-directory: test
run: |
cat package.json
cat package-lock.json
ls -r node_modules
ls -r node_modules\@supabase\supa-mdx-lint-win32-x64
npm run lint
3 changes: 3 additions & 0 deletions packages/supa-mdx-lint/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@
"name": "@supabase/supa-mdx-lint",
"version": "0.1.6-pre",
"main": "src/index.js",
"bin": {
"supa-mdx-lint": "src/index.js"
},
"scripts": {
"format": "prettier --write .",
"format:check": "prettier --check .",
Expand Down
5 changes: 1 addition & 4 deletions packages/supa-mdx-lint/src/helper.js
Original file line number Diff line number Diff line change
Expand Up @@ -127,9 +127,8 @@ function getBinaryPath() {
throwUnsupportedPlatformError();
}

let compatibleBinaryPath;
try {
compatibleBinaryPath = require.resolve(`${packageName}/${subpath}`);
return require.resolve(`${packageName}/${subpath}`);
} catch {
const otherInstalledDistribution = BINARY_DISTRIBUTIONS.find(
({ packageName, subpath }) => {
Expand All @@ -155,8 +154,6 @@ To fix this, avoid copying the "node_modules" folder, and instead freshly instal
It seems like none of the "@supabase/supa-mdx-lint" package's optional dependencies got installed. Please make sure your package manager is configured to install optional dependencies. If you are using npm to install your dependencies, please don't set the "--no-optional", "--ignore-optional", or "--omit=optional" flags. supa-mdx-lint needs the "optionalDependencies" feature in order to install its binary.`);
}
}

return compatibleBinaryPath;
}

/**
Expand Down
2 changes: 2 additions & 0 deletions packages/supa-mdx-lint/src/index.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#!/usr/bin/env node

//@ ts-check

"use strict";
Expand Down

0 comments on commit 4faabe6

Please sign in to comment.