Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 22 additions & 64 deletions actions/package/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,62 +3,12 @@
# ![Icon]() GitHub Action: Package

<div align="center">
<img src="https://opengraph.githubassets.com/0b6ae3eedb6db1767aa580568b2b8537a53dce2d0080866a902253850c40f7bd/hoverkraft-tech/ci-github-nodejs" width="60px" align="center" alt="Package" />
<img src="https://opengraph.githubassets.com/4f96f3249d1151f63aed208674e7891f457414a36b8c7799ccaa893c5a4beca3/hoverkraft-tech/ci-github-nodejs" width="60px" align="center" alt="Package" />
</div>

---

<!-- header:end -->

## Overview

Action to create and upload an npm package tarball from a Node.js project.

## Usage

```yaml
- uses: hoverkraft-tech/ci-github-nodejs/actions/package@c9d9d041ba4ef35695ee469c4782fa6a8bbebbcc # 0.21.2
with:
# Working directory where the package is packed.
# Can be absolute or relative to the repository root.
#
# Default: `.`
working-directory: .

# Optional build artifact ID to download before packaging.
build-artifact-id: ""

# Optional version to apply with `npm version` before packaging.
# The version is applied without creating a git tag.
version: ""

# Name of the uploaded package tarball artifact
# Default: `package-tarball`
artifact-name: package-tarball
```

## Inputs

| **Input** | **Description** | **Required** | **Default** |
| ----------------------- | ---------------------------------------------------------------- | ------------ | ----------------- |
| **`working-directory`** | Working directory where the package is packed. | **false** | `.` |
| | Can be absolute or relative to the repository root. | | |
| **`build-artifact-id`** | Optional build artifact ID to download before packaging. | **false** | - |
| | When provided, the artifact will be downloaded to the workspace. | | |
| **`version`** | Optional version to apply with `npm version` before packaging. | **false** | - |
| | The version is applied without creating a Git tag. | | |
| **`artifact-name`** | Name of the uploaded package tarball artifact | **false** | `package-tarball` |

## Outputs

| **Output** | **Description** |
| --------------------------------- | ---------------------------------------------- |
| **`package-tarball-path`** | Absolute path to the generated package tarball |
| **`package-tarball-artifact-id`** | Artifact ID of the uploaded package tarball |

## Contributing

Contributions are welcome! Please see the [contributing guidelines](https://github.com/hoverkraft-tech/ci-github-nodejs/blob/main/CONTRIBUTING.md) for more details.
<!-- badges:start -->

[![Marketplace](https://img.shields.io/badge/Marketplace-package-blue?logo=github-actions)](https://github.com/marketplace/actions/package)
Expand All @@ -80,14 +30,19 @@ Action to create and upload an npm package tarball from a Node.js project
## Usage

```yaml
- uses: hoverkraft-tech/ci-github-nodejs/actions/package@775ce0902c528062cc94141dd7d13261083b752a # 0.22.0
- uses: hoverkraft-tech/ci-github-nodejs/actions/package@f81c0d625c99d16be16427d82737651df1af5ee9 # main
with:
# Working directory where the package is packed.
# Working directory where dependencies are installed for packaging.
# Can be absolute or relative to the repository root.
#
# Default: `.`
working-directory: .

# Optional package directory to version and pack.
# Can be absolute or relative to `working-directory`.
# Useful for monorepos where dependencies are installed at the root.
package-directory: ""

# Optional build artifact ID to download before packaging.
# When provided, the artifact will be downloaded to the workspace.
build-artifact-id: ""
Expand All @@ -112,17 +67,20 @@ Action to create and upload an npm package tarball from a Node.js project

## Inputs

| **Input** | **Description** | **Required** | **Default** |
| ------------------------- | ------------------------------------------------------------------------------------------- | ------------ | ------------------------- |
| **`working-directory`** | Working directory where the package is packed. | **false** | `.` |
| | Can be absolute or relative to the repository root. | | |
| **`build-artifact-id`** | Optional build artifact ID to download before packaging. | **false** | - |
| | When provided, the artifact will be downloaded to the workspace. | | |
| **`build-artifact-path`** | Optional path to the build artifact contents relative to the workspace root. | **false** | `${{ github.workspace }}` |
| | Used to locate the files to be included in the package when a build artifact is downloaded. | | |
| **`version`** | Optional version to apply with `npm version` before packaging. | **false** | - |
| | The version is applied without creating a Git tag. | | |
| **`artifact-name`** | Name of the uploaded package tarball artifact | **false** | `package-tarball` |
| **Input** | **Description** | **Required** | **Default** |
| ------------------------- | ------------------------------------------------------------------------------------------- | ------------ | --------------------------- |
| **`working-directory`** | Working directory where dependencies are installed for packaging. | **false** | `.` |
| | Can be absolute or relative to the repository root. | | |
| **`package-directory`** | Optional package directory to version and pack. | **false** | - |
| | Can be absolute or relative to `working-directory`. | | |
| | Useful for monorepos where dependencies are installed at the root. | | |
| **`build-artifact-id`** | Optional build artifact ID to download before packaging. | **false** | - |
| | When provided, the artifact will be downloaded to the workspace. | | |
| **`build-artifact-path`** | Optional path to the build artifact contents relative to the workspace root. | **false** | `$\{\{ github.workspace }}` |
| | Used to locate the files to be included in the package when a build artifact is downloaded. | | |
| **`version`** | Optional version to apply with `npm version` before packaging. | **false** | - |
| | The version is applied without creating a Git tag. | | |
| **`artifact-name`** | Name of the uploaded package tarball artifact | **false** | `package-tarball` |

<!-- inputs:end -->
<!-- secrets:start -->
Expand Down
23 changes: 20 additions & 3 deletions actions/package/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,17 @@ branding:
inputs:
working-directory:
description: |
Working directory where the package is packed.
Working directory where dependencies are installed for packaging.
Can be absolute or relative to the repository root.
required: false
default: "."
package-directory:
description: |
Optional package directory to version and pack.
Can be absolute or relative to `working-directory`.
Useful for monorepos where dependencies are installed at the root.
required: false
default: ""
build-artifact-id:
description: |
Optional build artifact ID to download before packaging.
Expand Down Expand Up @@ -77,6 +84,7 @@ runs:
uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8.0.0
env:
WORKING_DIRECTORY: ${{ steps.working-directory.outputs.absolute-path }}
PACKAGE_DIRECTORY: ${{ inputs.package-directory }}
RELEASE_VERSION: ${{ inputs.version }}
RUNNER_TEMP: ${{ runner.temp }}
with:
Expand All @@ -85,19 +93,28 @@ runs:
const path = require('node:path');

const workingDirectory = process.env.WORKING_DIRECTORY;
const packageDirectoryInput = (process.env.PACKAGE_DIRECTORY || '').trim();
const packageDirectory = packageDirectoryInput ? path.resolve(workingDirectory, packageDirectoryInput) : workingDirectory;
core.debug(`Running in working directory: ${workingDirectory}`);
core.debug(`Package directory: ${packageDirectory}`);
process.chdir(workingDirectory);

const releaseVersion = (process.env.RELEASE_VERSION || '').trim();
const runnerTemp = process.env.RUNNER_TEMP;

const packageJsonPath = path.join(packageDirectory, 'package.json');
if (!fs.existsSync(packageJsonPath)) {
core.setFailed(`package.json not found in package directory: ${packageDirectory}`);
return;
}

if (releaseVersion) {
core.info(`Updating package version to provided release version: ${releaseVersion}`);
const npmVersionResult = await exec.getExecOutput(
'npm',
['version', releaseVersion, '--no-git-tag-version', '--no-workspaces-update'],
{
cwd: workingDirectory,
cwd: packageDirectory,
ignoreReturnCode: true,
},
);
Expand All @@ -109,7 +126,7 @@ runs:
}

const npmPackResult = await exec.getExecOutput('npm', ['pack', '--json', '--pack-destination', runnerTemp], {
cwd: workingDirectory,
cwd: packageDirectory,
ignoreReturnCode: true,
});

Expand Down
Loading