Compare commits

..

49 Commits

Author SHA1 Message Date
Thomas Hobson abec6cf244
ci(package): get list of packages from pr 2021-03-14 16:43:50 +13:00
Thomas Hobson 2c1ca22cdd
ci(package): test 2021-03-14 16:41:52 +13:00
Thomas Hobson 7bca798c0b
ci(package): test 2021-03-14 16:38:48 +13:00
Thomas Hobson baf00ada3d
ci(package): point to head 2021-03-14 16:21:01 +13:00
Thomas Hobson 00dd38b83d
repo: get changed files 2021-03-14 16:12:28 +13:00
Thomas Hobson f1a74a0d68
ci(api): pull using action 2021-03-14 16:06:42 +13:00
Thomas Hobson 0ae6ee1632
ci(repo): pull using action 2021-03-14 16:05:11 +13:00
Thomas Hobson 84757560fc
repo: verbosity 2021-03-14 16:03:40 +13:00
Thomas Hobson 4626176222
ci(package): use head commit 2021-03-14 15:56:17 +13:00
Thomas Hobson d10496cc78
ci(package): add git log?? 2021-03-14 15:49:59 +13:00
Thomas Hobson 14f582eb33
ci(package): use commit sha 2021-03-14 15:47:11 +13:00
Thomas Hobson ca3a4c3c0b
ci(package): get all commits 2021-03-14 15:43:24 +13:00
Thomas Hobson b36cb64105
api: revert quoting of args 2021-03-14 15:33:29 +13:00
Thomas Hobson bb8b0dbd91
ci(repo): pull existing container 2021-03-14 15:29:50 +13:00
Thomas Hobson 7fa1a4b5e0
ci(api): pull existing container 2021-03-14 15:29:44 +13:00
Thomas Hobson 46ae4a9487
repo: correct commit sha... 2021-03-14 15:28:45 +13:00
Thomas Hobson d9cacd2677
repo: use correct commit sha 2021-03-14 15:23:36 +13:00
Thomas Hobson 5c59400093
repo: more verbosity 2021-03-14 15:17:48 +13:00
Thomas Hobson fda944359a
ci(package): current dir... 2021-03-14 15:12:20 +13:00
Thomas Hobson d0f8932722
pkg(all): replace $* with "$@" 2021-03-14 15:11:33 +13:00
Thomas Hobson 55f45e05bc
ci(package): list out packages/repo 2021-03-14 15:10:08 +13:00
Thomas Hobson 02986e6a41
ci(package): pass in correct sha 2021-03-14 15:07:08 +13:00
Thomas Hobson b029276a67
ci(package): use correct docker image 2021-03-14 14:52:14 +13:00
Thomas Hobson fd8b8515f4
ci(package): testing 2021-03-14 14:51:29 +13:00
Thomas Hobson be1b93cf1f
repo: add CI mode 2021-03-14 14:50:55 +13:00
Thomas Hobson d529384f21
api: quote args when being executed 2021-03-14 13:57:14 +13:00
Thomas Hobson 7b57bef167
ci(package): test depends on build 2021-03-14 13:52:20 +13:00
Thomas Hobson db605e70fb
ci(package): indentation 2021-03-14 13:50:44 +13:00
Thomas Hobson 31b9e98b06
ci(package): remove privilege 2021-03-14 13:49:30 +13:00
Thomas Hobson 911de04d98
ci(package): name container correctly 2021-03-14 13:28:02 +13:00
Thomas Hobson 9a6616107b
ci(package): start both containers in tests 2021-03-14 13:25:43 +13:00
Thomas Hobson 22e32be05b
repo: verbosity 2021-03-14 13:21:06 +13:00
Thomas Hobson 71d675f454
repo: exit with zero exit code 2021-03-14 13:06:04 +13:00
Thomas Hobson 41e036d93c
ci(package): login to registry 2021-03-14 13:02:54 +13:00
Thomas Hobson 0ff42adeaa
ci(package): use prebuilt images 2021-03-14 13:01:32 +13:00
Thomas Hobson 2e20928bc8
ci: add path filters 2021-03-14 13:00:15 +13:00
Thomas Hobson 7ce8afa7f2
ci(repo): Initial Commit 2021-03-14 12:57:37 +13:00
Thomas Hobson bebbbd8ecb
ci(package): mount volumes in container correctly 2021-03-14 12:44:11 +13:00
Thomas Hobson fba88356e9
ci(package): correct version 2021-03-14 12:39:26 +13:00
Thomas Hobson 1bc46ed45c
ci(package): version on action 2021-03-14 12:38:10 +13:00
Thomas Hobson 72617c1e2e
ci(package): fix 2021-03-14 12:36:19 +13:00
Thomas Hobson 6c0d78391e
ci(package): build package 2021-03-14 12:34:54 +13:00
Thomas Hobson bf3550200d
ci(api): remove useless parameter 2021-03-14 12:34:18 +13:00
Thomas Hobson 803b836933
repo: allow build only 2021-03-14 12:33:15 +13:00
Thomas Hobson 8cc91a375c
ci(api): name correctly 2021-03-14 12:20:21 +13:00
Thomas Hobson b94c20b334
ci(api): update actions to latest version 2021-03-14 12:18:37 +13:00
Thomas Hobson 078033b4a1
ci(api): set docker build context correctly 2021-03-14 12:03:22 +13:00
Thomas Hobson 8a7d4100d7
ci(api): fix 2021-03-14 12:02:06 +13:00
Thomas Hobson 0e759c2729
ci(api): Add CI to build API container 2021-03-14 12:00:43 +13:00
25 changed files with 196 additions and 79 deletions

32
.github/workflows/api-push.yaml vendored Normal file
View File

@ -0,0 +1,32 @@
name: Publish API image
on:
push:
branches:
- master
- v3
paths:
- api/**
jobs:
push_to_registry:
runs-on: ubuntu-latest
name: Build and Push Docker image to Github Packages
steps:
- name: Check out repo
uses: actions/checkout@v2
- name: Login to GitHub registry
uses: docker/login-action@v1
with:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: docker.pkg.github.com
- name: Build and push API
uses: docker/build-push-action@v2
with:
context: api
push: true
pull: true
tags: |
docker.pkg.github.com/engineer-man/piston/api

View File

@ -11,63 +11,78 @@ on:
- 'packages/**' - 'packages/**'
jobs: jobs:
check-build: build-pkg:
name: Check that package builds name: Check that package builds
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Get PR Commits
id: 'get-pr-commits'
uses: tim-actions/get-pr-commits@master
with:
token: ${{ secrets.GITHUB_TOKEN }}
- name: Check subsystem
uses: tim-actions/commit-message-checker-with-regex@v0.3.1
with:
commits: ${{ steps.get-pr-commits.outputs.commits }}
pattern: '^[\s]*(pkg\([^:\s\n]+\))[\s]*:'
error: 'Your commit message must start with pkg([package])'
- name: Get packages
id: 'get-packages'
shell: bash
run: |
COMMITS='${{ steps.get-pr-commits.outputs.commits }}'
PACKAGES=$(echo $COMMITS | jq .[].commit.message -r | grep -oP '^pkg\(\K[^:\h\n]+(?=\))' | sort -u)
echo "::set-output name=packages::$PACKAGES"
- name: Checkout - name: Checkout
uses: actions/checkout@v2 uses: actions/checkout@v2
- name: Build docker containers - name: Login to GitHub registry
run: | uses: docker/login-action@v1
docker build -t piston_fs_repo repo with:
docker build -t piston_api api username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: docker.pkg.github.com
- name: Get list of changed files
uses: lots0logs/gh-action-get-changed-files@2.1.4
with:
token: ${{ secrets.GITHUB_TOKEN }}
- name: Build Packages - name: Build Packages
run: | run: |
docker run -v $(pwd)'/repo:/repo' -v $(pwd)'/packages:/packages' piston_fs_repo ${{ steps.get-packages.outputs.packages }} PACKAGES=$(jq '.[]' -r ${HOME}/files.json | awk -F/ '{ print $2 "-" $3 }' | sort -u)
echo "Packages: $PACKAGES"
docker run -v "${{ github.workspace }}:/piston" docker.pkg.github.com/engineer-man/piston/repo-builder:latest --no-server $PACKAGES
ls -la packages
- name: Upload package as artifact
uses: actions/upload-artifact@v2
with:
name: packages
path: packages/*.pkg.tar.gz
test-pkg:
name: Test package
runs-on: ubuntu-latest
needs: build-pkg
steps:
- uses: actions/checkout@v2
- uses: actions/download-artifact@v2
with:
name: packages
- name: Write test config file
uses: DamianReeves/write-file-action@v1.0
with:
path: data/config.yaml
contents: |
log_level: DEBUG
bind_address: 0.0.0.0:6969
data_directory: /piston
runner_uid_min: 1100
runner_uid_max: 1500
runner_gid_min: 1100
runner_gid_max: 1500
enable_unshare: false
output_max_size: 1024
max_process_count: 64
max_open_files: 2048
repo_url: http://piston_fs_repo:8000/index
write-mode: overwrite
- name: Run tests - name: Run tests
run: | run: |
docker run -p 6969:6969 -v $(pwd)'/data:/piston' -v $(pwd)'/repo:/repo' --privileged --name api piston_api & docker run -v $(pwd)'/repo:/piston/repo' -v $(pwd)'/packages:/piston/packages' --name piston_fs_repo docker.pkg.github.com/engineer-man/piston/repo-builder $PACKAGES &
docker run -v $(pwd)'/data:/piston' --name api docker.pkg.github.com/engineer-man/piston/api &
echo Waiting for API to start.. echo Waiting for API to start..
while [[ "$(curl -s -w '%{http_code}' http://127.0.0.1:6969/runtimes)" != "200" ]]; do sleep 5; done while [[ "$(curl -s -w '%{http_code}' http://api:6969/runtimes)" != "200" ]]; do sleep 5; done
echo Adding local repo
curl -s http://127.0.0.1:6969/repos -XPOST -d "slug=local&url=file:///repo/index.yaml"
echo Testing packages echo Testing packages
for pkg in "$(curl -s http://127.0.0.1:6969/repos/local/packages/ | jq '.data.packages[] | "\(.language)/\(.language_version)"' -r)"
do
PKG_SLUG=${pkg/\//-}
PKG_NAME=$(echo $pkg | cut -d'/' -f 1)
PKG_VERSION=$(echo $pkg | cut -d'/' -f 2)
echo Installing ${PKG_SLUG}
curl -sXPOST http://127.0.0.1:6969/repos/local/packages/${pkg} | jq '.language' -r || exit 1
echo Testing ${PKG_SLUG} (using ${PKG_SLUG}.tf)
TEST_FILE=$(cat ${PKG_SLUG}.tf)
TEST_JSON=`jq -C '.language = "${PKG_NAME}" | .version = "${PKG_VERSION}" | .files=[] | .files[0]={} | .files[0].name="test" | .files[0].name.content="${TEST_FILE}" | .main = "test" | .args = [] | .stdin = "" | .compile_timeout = 10000 | .run_timeout = 3000' <<< '{}'`
curl -sXPOST http://127.0.0.1:6969/jobs -H 'Content-Type: application/json' -d "$TEST_JSON" > ${PKG_SLUG}.tr
jq '.run.stdout' ${PKG_SLUG}.tr | grep "OK" || exit 1
done

31
.github/workflows/repo-push.yaml vendored Normal file
View File

@ -0,0 +1,31 @@
name: Publish Repo image
on:
push:
branches:
- master
- v3
paths:
- repo/**
jobs:
push_to_registry:
runs-on: ubuntu-latest
name: Build and Push Docker image to Github Packages
steps:
- name: Check out repo
uses: actions/checkout@v2
- name: Login to GitHub registry
uses: docker/login-action@v1
with:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
registry: docker.pkg.github.com
- name: Build and push repo
uses: docker/build-push-action@v2
with:
context: repo
pull: true
push: true
tags: |
docker.pkg.github.com/engineer-man/piston/repo-builder

View File

@ -81,7 +81,8 @@ class Job {
const proc_call = [ const proc_call = [
...prlimit, ...prlimit,
...unshare, ...unshare,
'bash',file, ...args 'bash',file,
...args
]; ];
var stdout = ''; var stdout = '';

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Put instructions to run the runtime # Put instructions to run the runtime
bash $* bash "$@"

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Put instructions to run the runtime # Put instructions to run the runtime
dart run $* dart run "$@"

View File

@ -1,2 +1,2 @@
#!/bin/bash #!/bin/bash
DENO_DIR=$PWD deno run $* DENO_DIR=$PWD deno run "$@"

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Put instructions to run the runtime # Put instructions to run the runtime
gawk-5.1.0 -f $* gawk-5.1.0 -f "$@"

View File

@ -5,16 +5,16 @@
case "${PISTON_ALIAS}" in case "${PISTON_ALIAS}" in
gcc | c) gcc | c)
gcc -std=c11 $* -lm gcc -std=c11 "$@" -lm
;; ;;
g++ | c++ | cpp) g++ | c++ | cpp)
g++ -std=c++17 $* g++ -std=c++17 "$@"
;; ;;
gccgo | go) gccgo | go)
gccgo $* gccgo "$@"
;; ;;
gdc | d) gdc | d)
gdc $* gdc "$@"
;; ;;
*) *)
echo "How did you get here? (${PISTON_ALIAS})" echo "How did you get here? (${PISTON_ALIAS})"

View File

@ -3,4 +3,4 @@
# Put instructions to run the runtime # Put instructions to run the runtime
shift # Discard main filename shift # Discard main filename
./a.out $* ./a.out "$@"

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Put instructions to run the runtime # Put instructions to run the runtime
java $* java "$@"

View File

@ -1 +1 @@
jelly fu $* jelly fu "$@"

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Put instructions to compile source code, remove this file if the language does not require this stage # Put instructions to compile source code, remove this file if the language does not require this stage
kotlinc $* -include-runtime -d code.jar kotlinc "$@" -include-runtime -d code.jar

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
csc $* csc "$@"

View File

@ -2,4 +2,4 @@
CODE=${1/cs/exe} CODE=${1/cs/exe}
shift shift
mono $CODE $* mono $CODE "$@"

View File

@ -5,11 +5,11 @@
case "${PISTON_ALIAS}" in case "${PISTON_ALIAS}" in
nasm) nasm)
nasm -f elf32 -o binary.o $* nasm -f elf32 -o binary.o "$@"
ld -m elf_i386 binary.o -o binary ld -m elf_i386 binary.o -o binary
;; ;;
nasm64) nasm64)
nasm -f elf64 -o binary.o $* nasm -f elf64 -o binary.o "$@"
ld -m elf_x86_64 binary.o -o binary ld -m elf_x86_64 binary.o -o binary
;; ;;
*) *)

View File

@ -2,4 +2,4 @@
# Put instructions to run the runtime # Put instructions to run the runtime
shift shift
./binary $* ./binary "$@"

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
node $* node "$@"

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
php $* php "$@"

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
python3.9 $* python3.9 "$@"

View File

@ -2,4 +2,4 @@
# Put instructions to compile source code, remove this file if the language does not require this stage # Put instructions to compile source code, remove this file if the language does not require this stage
tsc $* tsc "$@"

View File

@ -5,4 +5,4 @@
CODE=$(sed 's/ts$/js/' <<<"$1") CODE=$(sed 's/ts$/js/' <<<"$1")
shift shift
node $CODE $* node $CODE "$@"

View File

@ -2,10 +2,9 @@ FROM debian:buster-slim
RUN apt-get update && apt-get install -y unzip autoconf build-essential libssl-dev pkg-config zlib1g-dev libargon2-dev libsodium-dev libcurl4-openssl-dev sqlite3 libsqlite3-dev libonig-dev libxml2 libxml2-dev bc curl git linux-headers-amd64 perl xz-utils python3 python3-pip gnupg jq zlib1g-dev cmake cmake-doc extra-cmake-modules build-essential gcc binutils bash coreutils util-linux pciutils usbutils coreutils binutils findutils grep && \ RUN apt-get update && apt-get install -y unzip autoconf build-essential libssl-dev pkg-config zlib1g-dev libargon2-dev libsodium-dev libcurl4-openssl-dev sqlite3 libsqlite3-dev libonig-dev libxml2 libxml2-dev bc curl git linux-headers-amd64 perl xz-utils python3 python3-pip gnupg jq zlib1g-dev cmake cmake-doc extra-cmake-modules build-essential gcc binutils bash coreutils util-linux pciutils usbutils coreutils binutils findutils grep && \
ln -sf /bin/bash /bin/sh && \ ln -sf /bin/bash /bin/sh && \
pip3 install 'yq==2.12.0' && \
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
ADD *.sh / ADD entrypoint.sh mkindex.sh /
ENTRYPOINT ["bash","/entrypoint.sh"] ENTRYPOINT ["bash","/entrypoint.sh"]
CMD ["all"] CMD ["--no-build"]

View File

@ -1,7 +0,0 @@
# Piston Filesystem Repo Builder
This is just a simple POC for a repository tool to run locally.
This only demonstrates building an unsigned python-3.9.1 package, however if it finds an `asc` file it will include it as the signature.
Mount this whole directory into `/repo` in your API container if you wish to use it.

View File

@ -1,11 +1,57 @@
cd /piston/packages cd /piston/packages
SERVER=1
BUILD=1
CI=0
echo "Running through arguments.."
for pkg in "$@" for pkg in "$@"
do do
shift
if [[ "$pkg" = "--no-server" ]]; then
echo "Not starting index server after builds"
SERVER=0
elif [[ "$pkg" = "--no-build" ]]; then
echo "Building no more package"
BUILD=0
elif [[ "$pkg" = "--ci" ]]; then
echo "Running in CI mode, --no-build, --no-server"
BUILD=0
SERVER=0
CI=1
else
if [[ $BUILD -eq 1 ]]; then
echo "Building package $pkg"
make -j16 $pkg.pkg.tar.gz make -j16 $pkg.pkg.tar.gz
echo "Done with package $pkg"
elif [[ $CI -eq 1 ]]; then
echo "Commit SHA: $pkg"
echo "Changed files:"
git diff --name-only $pkg^1 $pkg
PACKAGES=$(git diff --name-only $pkg^1 $pkg | awk -F/ '{ print $2 "-" $3 }' | sort -u)
echo "Building packages: $PACKAGES"
for package in "$PACKAGES"; do
make -j16 $package.pkg.tar.gz
done
else
echo "Building was disabled, skipping $pkg build=$BUILD ci=$CI"
fi
fi
done done
cd /piston/repo cd /piston/repo
echo "Creating index"
./mkindex.sh ./mkindex.sh
echo "Index created"
python3 -m http.server if [[ $SERVER -eq 1 ]]; then
echo "Starting index server.."
python3 -m http.server
else
echo "Skipping starting index server"
fi
exit 0