Skip to content
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

Update README.md according to Heroku CNB guidelines #217

Merged
merged 4 commits into from
Mar 16, 2024
Merged
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
75 changes: 40 additions & 35 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,54 +1,59 @@
# Heroku Cloud Native Procfile Buildpack
# Heroku Cloud Native Buildpack: Procfile

[![CI](https://github.com/heroku/buildpacks-procfile/actions/workflows/ci.yml/badge.svg)](https://github.com/heroku/buildpacks-procfile/actions/workflows/ci.yml)
[![Cloud Native Buildpacks Registry: heroku/procfile][registry-badge]][registry-url]
[![CI on Github Actions: heroku/procfile][ci-badge]][ci-url]

This is a [Cloud Native Buildpack](https://buildpacks.io/) that replicates the behavior of
[`Procfile`](https://devcenter.heroku.com/articles/procfile) from non-CNB Heroku Builds.

It is written in Rust using the Cloud Native Buildpack framework [libcnb.rs](https://github.com/heroku/libcnb.rs).
`heroku/procfile` is the [Heroku Cloud Native Buildpack][heroku-buildpacks]
for Procfile applications. It replicates the behavior of [`Procfile`](https://devcenter.heroku.com/articles/procfile)
runesoerensen marked this conversation as resolved.
Show resolved Hide resolved
from builds on the Heroku Platform.

## Development
> [!IMPORTANT]
> This is a [Cloud Native Buildpack][cnb], and is a component of the [Heroku Cloud Native Buildpacks][heroku-buildpacks] project, which is in preview.

### Prerequisites
## Usage

See [Development Environment Setup](https://github.com/heroku/libcnb.rs#development-environment-setup).
> [!NOTE]
> Before getting started, ensure you have the `pack` CLI installed. Installation instructions are available [here][pack-install].

### Test
To build an application codebase with a `Procfile` into a production image:

Run unit tests:

```
$ cargo test
```bash
$ cd ~/workdir/sample-procfile-app
$ pack build sample-app --builder heroku/builder:22
```

Run integration tests:

```
$ cargo test -- --ignored
Then run the image:
```bash
docker run --rm -it -e "PORT=8080" -p 8080:8080 sample-app
```

Or to run all of the tests at the same time:
## Application Requirements

```
$ cargo test -- --include-ignored
```
This buildpack requires a properly formatted [`Procfile`](https://devcenter.heroku.com/articles/procfile)
to exist in the root project directory.

### Pack build example
## Configuration

```
$ cargo libcnb package \
&& pack build procfile_example_app --builder heroku/builder:22 --buildpack target/buildpack/debug/heroku_procfile --path tests/fixtures/web_and_worker_procfile --verbose \
&& docker run -it --rm --entrypoint worker procfile_example_app
```
You may configure which processes are included in a build result by using a
YAML-like syntax with bash commands:
runesoerensen marked this conversation as resolved.
Show resolved Hide resolved

```yaml
# Example Procfile
web: bundle exec rails server -p $PORT
worker: bundle exec rake jobs:work
```
$ pack inspect procfile_example_app | grep -A10 Processes
Processes:
TYPE SHELL COMMAND ARGS WORK DIR
web (default) bash echo 'this is the web process!' /workspace
worker bash echo 'this is the worker process!' /workspace
```

## Releasing
## Contributing

Issues and pull requests are welcome. See our [contributing guidelines](./CONTRIBUTING.md) if you would like to help.


[Deploy Cloud Native Buildpacks](https://github.com/heroku/languages-team/blob/main/languages/cnb/deploy.md)
[ci-badge]: https://github.com/heroku/buildpacks-procfile/actions/workflows/ci.yml/badge.svg
[ci-url]: https://github.com/heroku/buildpacks-procfile/actions/workflows/ci.yml
[cnb]: https://buildpacks.io
[classic-buildpack]: https://github.com/heroku/heroku-buildpack-procfile
[heroku-buildpacks]: https://github.com/heroku/buildpacks
[pack-install]: https://buildpacks.io/docs/for-platform-operators/how-to/integrate-ci/pack/
[registry-badge]: https://img.shields.io/badge/dynamic/json?url=https://registry.buildpacks.io/api/v1/buildpacks/heroku/procfile&label=version&query=$.latest.version&color=DF0A6B&logo=&labelColor=white
[registry-url]: https://registry.buildpacks.io/buildpacks/heroku/procfile