Skip to content

format

format #3

Workflow file for this run

name: check
on:
push:
branches:
- main
pull_request:
jobs:
cla-check:
runs-on: ubuntu-latest
if: github.event_name == 'pull_request'
outputs:
cla-signed: ${{ steps.cla-check-step.outputs.cla-signed }}
steps:
- name: CLA check
id: cla-check-step
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
PR_AUTHOR=$(curl -s -H "Authorization: token $GITHUB_TOKEN" \
https://api.github.com/repos/${{ github.repository }}/pulls/${{ github.event.number }} \
| jq -r '.user.login')
echo "The PR author is $PR_AUTHOR"
CLA_RESPONSE=$(curl -s "https://mooncakes.io/api/v0/cla/check?gh_username=$PR_AUTHOR")
echo "CLA check response: $CLA_RESPONSE"
SIGNED=$(echo $CLA_RESPONSE | jq -r '.signed')
echo "cla-signed=$SIGNED" >> $GITHUB_ENV
echo "If you have any questions about the CLA result, please contact us."
if [ "$SIGNED" != "true" ]; then
echo "CLA is not signed."
exit 1
else
echo "CLA is signed."
fi
build:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: install
run: |
/bin/bash -c "$(curl -fsSL https://cli.moonbitlang.com/ubuntu_x86_64_moon_setup.sh)"
echo "/home/runner/.moon/bin" >> $GITHUB_PATH
- name: moon check
run: moon check
- name: moon test
run: moon test
- name: moon bundle
run: moon bundle
- name: check core size
run: ls -alh `find ./target/bundle -name *.core`
- name: format diff
run: |
moon fmt
git diff
build-on-mac:
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
- name: install
run: |
/bin/bash -c "$(curl -fsSL https://cli.moonbitlang.com/mac_intel_moon_setup.sh)"
echo "$HOME/.moon/bin" >> $GITHUB_PATH
- name: moon check
run: moon check
- name: moon test
run: moon test
- name: moon bundle
run: moon bundle
- name: check core size
run: ls -alh `find ./target/bundle -name *.core`
- name: format diff
run: |
moon fmt
git diff
build-on-mac-bleeding:
runs-on: macos-14
continue-on-error: true
steps:
- uses: actions/checkout@v4
- name: install
run: |
/bin/bash -c "$(curl -fsSL https://cli.moonbitlang.com/bleeding/mac_m1_moon_setup.sh)"
echo "$HOME/.moon/bin" >> $GITHUB_PATH
- name: moon check
run: moon check
- name: moon test
run: moon test
- name: moon bundle
run: moon bundle
- name: check core size
run: ls -alh `find ./target/bundle -name *.core`
- name: format diff
run: |
moon fmt
git diff
# coverage-check-bleeding:
# runs-on: macos-14
# continue-on-error: true
# permissions: write-all
# # contents: read
# # issues: write
# # pull-requests: write
# steps:
# - uses: actions/checkout@v4
# - name: install
# run: |
# /bin/bash -c "$(curl -fsSL https://cli.moonbitlang.com/bleeding/mac_m1_moon_setup.sh)"
# echo "$HOME/.moon/bin" >> $GITHUB_PATH
# - name: moon test
# run: moon test --enable-coverage
# - name: moon_cove_report
# run: moon_cove_report
# - name: bisect_ppx report
# run: |
# bisect-ppx-report html
# bisect-ppx-report summary > coverage_summary.txt
# echo "coverage_summary=$(cat coverage_summary.txt)" >> $GITHUB_ENV
# - name: upload coverage artifact
# uses: actions/upload-artifact@v4
# with:
# name: code-coverage-report
# path: _coverage
# - name: Add coverage comment to PR
# if: github.event_name == 'pull_request'
# uses: actions/github-script@v7
# with:
# script: |
# const coverageReportLink = `https://github.com/${process.env.GITHUB_REPOSITORY}/actions/runs/${process.env.GITHUB_RUN_ID}`;
# const prNumber = context.payload.pull_request.number;
# const summary = process.env.coverage_summary;
# await github.rest.issues.createComment({
# owner: context.repo.owner,
# repo: context.repo.repo,
# issue_number: prNumber,
# body: `${summary}\nCoverage report: ${coverageReportLink}`
# });
typo-check:
runs-on: ubuntu-latest
timeout-minutes: 10
env:
FORCE_COLOR: 1
TYPOS_VERSION: v1.19.0
steps:
- name: download typos
run: curl -LsSf https://github.com/crate-ci/typos/releases/download/$TYPOS_VERSION/typos-$TYPOS_VERSION-x86_64-unknown-linux-musl.tar.gz | tar zxf - -C ${CARGO_HOME:-~/.cargo}/bin
- name: Checkout repository
uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha }}
- name: check typos
run: typos
license-header-check:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Check License Header
uses: korandoru/hawkeye@v5