Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ztombol/bats-docs
Shared Bats helper documentation
https://github.com/ztombol/bats-docs
Last synced: 2 months ago
JSON representation
Shared Bats helper documentation
- Host: GitHub
- URL: https://github.com/ztombol/bats-docs
- Owner: ztombol
- License: cc0-1.0
- Created: 2016-02-09T23:54:57.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2022-01-12T18:37:20.000Z (almost 3 years ago)
- Last Synced: 2024-08-02T16:43:10.600Z (5 months ago)
- Size: 10.7 KB
- Stars: 60
- Watchers: 8
- Forks: 13
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome-starred - ztombol/bats-docs - Shared Bats helper documentation (Others)
README
# Overview
This is a proposal describing how a [Bats][bats] helper library should
look and behave. These guidelines and the libraries following them
resulted from the discussion about [introducing a Standard Library of
Test Helpers for Bats][bats-pr-110].Topics:
- [Installation](#installation)
- [Loading](#loading)
- [Testing](#testing)Libraries:
- [`bats-support`][bats-support] (formerly `bats-core`) - supporting
library for test helpers
- [`bats-assert`][bats-assert] - common assertions
- [`bats-file`][bats-file] - filesystem related assertions# Installation
There are multiple supported installation methods. One may be better
than the others depending on your case. Make sure to install the
required dependencies as well (e.g. install `bats-support` when
installing `bats-assert`).## npm
If your project is managed by npm, the recommended installation method is
also via npm.```sh
$ npm install --save-dev https://github.com/ztombol/bats-support
$ npm install --save-dev https://github.com/ztombol/bats-assert
```## Homebrew
OS X users can use [Homebrew](http://brew.sh/) to install libraries
system-wide (see note below for alternatives).The forumlae are in a tap for various shell utilities by
[@kaos](https://github.com/kaos), so enable the tap
[kaos/shell](https://github.com/kaos/homebrew-shell) first.```sh
$ brew tap kaos/shell
```Then install the desired libraries.
```sh
$ brew install bats-assert
$ brew install bats-file
```*__Note:__ The required dependencies, `bats-support` as well as `bats`
from the core tap will be installed automatically for you, with any of
the two previous commands.**__Note:__ Homebrew installs packages in a system-wide `/usr/local`
prefix by default. This is encouraged praxis when using `brew`, but
optional. See
[Alternative Installs](https://github.com/Homebrew/brew/blob/master/share/doc/homebrew/Installation.md#alternative-installs)
from the Homebrew documentation for details.*## Git submodule
If your project uses Git, the recommended method of installation is via
a [submodule][git-book-submod].*__Note:__ The following example installs libraries in the
`./test/test_helper` directory.*```sh
$ git submodule add https://github.com/ztombol/bats-support test/test_helper/bats-support
$ git commit -m 'Add bats-support library'
```## Git clone
If you do not use Git for version control, simply
[clone][git-book-clone] the repository.*__Note:__ The following example installs libraries in the
`./test/test_helper` directory.*```sh
$ git clone https://github.com/ztombol/bats-support test/test_helper/bats-support
```# Loading
A library is loaded by sourcing the `load.bash` file in its main
directory.Assuming that libraries are installed in `test/test_helper`, adding the
following line to a file in the `test` directory loads the
`bats-support` library.```sh
load 'test_helper/bats-support/load'
```For npm installations, load the libraries from `node_modules`:
```sh
load '../node_modules/bats-support/load'
load '../node_modules/bats-assert/load'
```For brew installations, load the libraries from `$(brew
--prefix)/lib/` (the brew prefix is `/usr/local` by default):```sh
TEST_BREW_PREFIX="$(brew --prefix)"
load "${TEST_BREW_PREFIX}/lib/bats-support/load.bash"
load "${TEST_BREW_PREFIX}/lib/bats-assert/load.bash"
```*__Note:__ The [`load` function][bats-load] sources a file (with
`.bash` extension automatically appended) relative to the location of
the current test file.**__Note:__ The [`load` function][bats-load] does NOT append a `.bash`
extension automatically when loading a file using an absolute path.*If a library depends on other libraries, they must be loaded as well.
## Simple loading helper
You can create a shorthand to simplify library loading.
```sh
# Load a library from the `${BATS_TEST_DIRNAME}/test_helper' directory.
#
# Globals:
# none
# Arguments:
# $1 - name of library to load
# Returns:
# 0 - on success
# 1 - otherwise
load_lib() {
local name="$1"
load "test_helper/${name}/load"
}
```This function lets you load a library with only its name, instead of
having to type the entire installation path.```sh
load_lib bats-support
load_lib bats-assert
```# Testing
A library's test suite is located in its `test` subdirectory. Library
dependencies are loaded from `$TEST_DEPS_DIR`, which defaults to the
directory containing the library.For example, testing the `bats-assert` library requires the
`bats-support` to be present in the same directory by default.```
$ tree -L 1
.
├── bats-assert
└── bats-support2 directories, 0 files
$ bats bats-assert/test
```This simplifies testing in most cases, e.g. testing in development and
before running the project's test suite, but also allows easily
selecting dependencies, e.g. testing compatibility with different
versions.[bats]: https://github.com/sstephenson/bats
[bats-pr-110]: https://github.com/sstephenson/bats/pull/110
[bats-support]: https://github.com/ztombol/bats-support
[bats-assert]: https://github.com/ztombol/bats-assert
[bats-file]: https://github.com/ztombol/bats-file
[git-book-submod]: https://git-scm.com/book/en/v2/Git-Tools-Submodules
[git-book-clone]: https://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository#Cloning-an-Existing-Repository
[bats-load]: https://github.com/sstephenson/bats#load-share-common-code