Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sschmid/bee
🐝 bee - plugin-based bash automation
https://github.com/sschmid/bee
alpine android appstore automation bash bee build-automation build-tool continuous-integration deployment docker dotnet ios linux macos msbuild timesaver unity3d unix workflow
Last synced: 6 days ago
JSON representation
🐝 bee - plugin-based bash automation
- Host: GitHub
- URL: https://github.com/sschmid/bee
- Owner: sschmid
- License: mit
- Created: 2018-09-07T11:35:57.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-10-28T13:04:14.000Z (3 months ago)
- Last Synced: 2025-01-08T23:13:47.853Z (13 days ago)
- Topics: alpine, android, appstore, automation, bash, bee, build-automation, build-tool, continuous-integration, deployment, docker, dotnet, ios, linux, macos, msbuild, timesaver, unity3d, unix, workflow
- Language: Shell
- Homepage:
- Size: 1.37 MB
- Stars: 74
- Watchers: 9
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
![Bee-Header](readme/bee-header.png)
# 🐝 bee - plugin-based bash automation
[![CI](https://github.com/sschmid/bee/actions/workflows/ci.yml/badge.svg)](https://github.com/sschmid/bee/actions/workflows/ci.yml)
[![Coverage Status](https://coveralls.io/repos/github/sschmid/bee/badge.svg)](https://coveralls.io/github/sschmid/bee)
[![Chat](https://img.shields.io/badge/gitter-chat-ED1965.svg?logo=gitter)](https://gitter.im/sschmid/bee)
[![Twitter](https://img.shields.io/twitter/follow/s_schmid)](https://twitter.com/intent/follow?original_referer=https%3A%2F%2Fgithub.com%2Fsschmid%2Fbee&screen_name=s_schmid&tw_p=followbutton)## Automate Everything
bee is an open source platform aimed to simplify and standardize automation and deployment.
bee lets you automate every aspect of your development and release workflow.
bee runs everywhere - "it's just bash"*__Automate the entire process from building your app to uploading it to the app stores__*
Combine bee with continuous integration tools such as [GitHub Actions](https://github.com/features/actions),
[Jenkins](https://jenkins.io), [Travis CI](https://travis-ci.org) or [TeamCity](https://www.jetbrains.com/teamcity/)
to automatically build and distribute your applications.[**🐝 Continuous Integration**](https://github.com/sschmid/bee/wiki/Continuous-Integration)
## Plugins
bee is a bash package manager that runs plugins. Plugins are registered at beehub
which is the official bee plugin register: https://github.com/sschmid/beehubYou can register your own plugin at beehub by creating a pull request.
You can also create your own custom hubs or local plugins for your personal or private use.Plugins allow you to customize and personalize bee to fit any requirement.
Are you missing a task or feature? Create your own plugins and contribute to beehub!
Share your plugins with the bee community so everyone can start saving time today.Plugins and commands can easily be discovered with bee's built-in auto-completion! (see [bee-completion](#bee-completion))
[**🐝 Explore plugins**](https://github.com/sschmid/beehub)
--------------------------------------------------------------------------------
## Install
```
bash -c "$(curl -fsSL https://raw.githubusercontent.com/sschmid/bee/main/install)"
```## bee completion
bee automatically completes plugins and makes working with them fun and easy.
Add auto-completion support for bee
```
echo "complete -C bee bee" >> ~/.bashrc
```If you use [zsh](https://ohmyz.sh/) add those lines to your `~/.zshrc`
```
autoload bashcompinit
bashcompinit
complete -C bee bee
```## Update
```
bee update
```## Customize
bee is very flexible and can be customized heavily.
See [bee](https://github.com/sschmid/bee/blob/main/src/bee#L15-L32) and
[bee-run.bash](https://github.com/sschmid/bee/blob/main/src/bee-run.bash#L2-L5)
and overwrite default values in `~/.beerc`--------------------------------------------------------------------------------
# Questions?
Frequently asked questions:
# [➡ FAQ](https://github.com/sschmid/bee/wiki/FAQ)
--------------------------------------------------------------------------------
## Example
Run individual plugin functions like this:
```bash
bee semver major
bee changelog merge
bee github create_release
```or batch them for more efficiency
```bash
bee --batch \
'semver major' \
'changelog merge' \
'unity execute_method BuildIOS' \
'ios archive_project' \
'ios export' \
'ios upload' \
'github create_release'
```or compose custom functions using existing bee plugins
```bash
app::release() {
semver::major
changelog::merge
unity::execute_method BuildIOS
ios::archive_project
ios::export
ios::upload
github::create_release
slack::message $channel "New release $(semver::read)"
}
```Discover and run your function using the bee bash completion
```
bee app release
```Explanation
- `semver major` - bump the major version
- `changelog merge` - merge the latest changes into the changelog
- `unity execute_method BuildIOS` - build the Unity project
- `ios archive_project` - archive xcode project
- `ios export` - export archive
- `ios upload` - upload to [TestFlight](https://developer.apple.com/testflight/)
- `github create_release` - create a github release and optionally attach artifacts
- `slack message` - send a message via slack to notify the team about a new release## Learn more
Read more about bee, checkout more examples and contribute your first own plugin
[**🐝 Open the bee wiki**](https://github.com/sschmid/bee/wiki)