diff --git a/README.md b/README.md index 7918997..374ecb0 100644 --- a/README.md +++ b/README.md @@ -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) +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: +```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