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 4f63e2c
Show file tree
Hide file tree
Showing 4 changed files with 176 additions and 0 deletions.
167 changes: 167 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -197,3 +197,170 @@ 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
tar -xzf $tarballPath.FullName -C node-pkg
Get-ChildItem -Path node-pkg\package
- name: Install main package
run: |
cd test
npm install ..\node-pkg\package
- name: Verify lint executable (debug)
shell: pwsh
run: |
cd test\node_modules\@supabase\supa-mdx-lint-win32-x64\bin
Get-Item supa-mdx-lint.exe | Format-List -Property *
cd ../../../..
.\node_modules\@supabase\supa-mdx-lint-win32-x64\bin\supa-mdx-lint.exe --version
- 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
4 changes: 4 additions & 0 deletions packages/supa-mdx-lint/src/helper.js
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ function getBinaryPath() {
}

const { packageName, subpath } = getDistributionForThisPlatform();
console.log("Expected package location: %s/%s", packageName, subpath);

if (packageName === undefined) {
throwUnsupportedPlatformError();
Expand All @@ -131,6 +132,9 @@ function getBinaryPath() {
try {
compatibleBinaryPath = require.resolve(`${packageName}/${subpath}`);
} catch {
console.log("[DEBUG] Try resolving without subpath");
console.log(require.resolve(packageName));

const otherInstalledDistribution = BINARY_DISTRIBUTIONS.find(
({ packageName, subpath }) => {
try {
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 4f63e2c

Please sign in to comment.