envful 0.4.17

A tool to verify the presence of environment variables before running a process
Documentation
name: build

on:
  push:
    tags: ["v*.*.*"]

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - name: Checkout
        uses: actions/checkout@v1

      - name: Run tests
        run: cargo test --verbose

      - name: Install dependencies
        run: |
          sudo apt-get update
          sudo apt-get -y install gcc-mingw-w64-x86-64 gcc-mingw-w64-i686
          rustup target add x86_64-pc-windows-gnu
          rustup target add i686-pc-windows-gnu
          rustup target add x86_64-unknown-linux-gnu
          rustup target add x86_64-apple-darwin

          mkdir dist
          mkdir builds

      - name: Build Win64
        run: |
          cargo rustc --bin envful --release --target=x86_64-pc-windows-gnu -- -C linker=x86_64-w64-mingw32-gcc
          mkdir builds/envful-win64
          cp target/x86_64-pc-windows-gnu/release/envful.exe builds/envful-win64
          tar -C builds -czvf dist/envful-win64.tar.gz envful-win64

      - name: Build Linux
        run: |
          cargo rustc --bin envful --release --target=x86_64-unknown-linux-gnu
          mkdir builds/envful-linux
          cp target/x86_64-unknown-linux-gnu/release/envful builds/envful-linux
          tar -C builds -czvf dist/envful-linux.tar.gz envful-linux

      - name: Upload release
        uses: softprops/action-gh-release@v1
        with:
          body_path: CHANGELOG.md
          files: |
            dist/envful-win64.tar.gz
            dist/envful-linux.tar.gz
            dist/envful-macos.tar.gz
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

      - name: Publish npm package
        env:
          NPM_ACCESS_TOKEN: ${{ secrets.NPM_ACCESS_TOKEN }}
        run: |
          echo "//registry.npmjs.org/:_authToken=$NPM_ACCESS_TOKEN" > ".npmrc"
          npm publish

      - name: Publish cargo package
        env:
          CARGO_ACCESS_TOKEN: ${{ secrets.CARGO_ACCESS_TOKEN }}
        run: |
          cargo login "$CARGO_ACCESS_TOKEN"
          cargo publish