Add Shellcheck to Jenkins
This commit is contained in:
parent
b1fb158c9e
commit
1b98ebe27f
|
|
@ -1,2 +1,2 @@
|
||||||
FROM alpine
|
FROM alpine
|
||||||
RUN apk add make docker
|
RUN apk add make docker shellcheck
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,13 @@ pipeline {
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
|
stage('shellcheck') {
|
||||||
|
steps {
|
||||||
|
catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') {
|
||||||
|
sh "shellcheck compile-r7rs"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
stage('Test R6RS') {
|
stage('Test R6RS') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
|
|
|
||||||
49
Makefile
49
Makefile
|
|
@ -1,3 +1,4 @@
|
||||||
|
.SILENT: test
|
||||||
PREFIX=/usr/local
|
PREFIX=/usr/local
|
||||||
SCHEME=chibi
|
SCHEME=chibi
|
||||||
IMAGE=${SCHEME}:latest
|
IMAGE=${SCHEME}:latest
|
||||||
|
|
@ -12,30 +13,30 @@ install:
|
||||||
install compile-r7rs ${PREFIX}/bin/compile-r7rs
|
install compile-r7rs ${PREFIX}/bin/compile-r7rs
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@# Misc
|
# Misc
|
||||||
@rm -rf .tmp
|
rm -rf .tmp
|
||||||
@mkdir -p .tmp
|
mkdir -p .tmp
|
||||||
@mkdir -p .tmp/libs
|
mkdir -p .tmp/libs
|
||||||
@mkdir -p .tmp/libs/foo
|
mkdir -p .tmp/libs/foo
|
||||||
@mkdir -p .tmp/other_libs
|
mkdir -p .tmp/other_libs
|
||||||
@# R6RS testfiles
|
# R6RS testfiles
|
||||||
@printf "#!r6rs\n(import (rnrs) (foo bar))\n(baz)" > .tmp/main.sps
|
printf "#!r6rs\n(import (rnrs) (foo bar))\n(baz)" > .tmp/main.sps
|
||||||
@printf "#!r6rs\n(library (foo bar) (export baz) (import (rnrs)) (define (baz) (display \"Hello from bar.sls\") (newline)))" > .tmp/libs/foo/bar.sls
|
printf "#!r6rs\n(library (foo bar) (export baz) (import (rnrs)) (define (baz) (display \"Hello from bar.sls\") (newline)))" > .tmp/libs/foo/bar.sls
|
||||||
@# Racket compability testfiles
|
# Racket compability testfiles
|
||||||
@printf "#lang r7rs (import (scheme base)) (include \"bar.sld\")" > .tmp/libs/foo/bar.rkt
|
printf "#lang r7rs (import (scheme base)) (include \"bar.sld\")" > .tmp/libs/foo/bar.rkt
|
||||||
@# R7RS testfiles
|
# R7RS testfiles
|
||||||
@printf "(import (scheme base) (scheme write) (foo bar))\n(baz)" > .tmp/main.scm
|
printf "(import (scheme base) (scheme write) (foo bar))\n(baz)" > .tmp/main.scm
|
||||||
@printf "(define-library (foo bar) (import (scheme base) (scheme write)) (export baz) (include \"bar.scm\"))" > .tmp/libs/foo/bar.sld
|
printf "(define-library (foo bar) (import (scheme base) (scheme write)) (export baz) (include \"bar.scm\"))" > .tmp/libs/foo/bar.sld
|
||||||
@printf "(define (baz) (display \"Hello from bar.scm\") (newline))" > .tmp/libs/foo/bar.scm
|
printf "(define (baz) (display \"Hello from bar.scm\") (newline))" > .tmp/libs/foo/bar.scm
|
||||||
@# Tests
|
# Tests
|
||||||
@rm -rf .tmp/main
|
rm -rf .tmp/main
|
||||||
@if [ "${RNRS}" = "r6rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -I libs main.sps; fi
|
if [ "${RNRS}" = "r6rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -I libs main.sps; fi
|
||||||
@if [ "${RNRS}" = "r7rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -I libs main.scm; fi
|
if [ "${RNRS}" = "r7rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -I libs main.scm; fi
|
||||||
@cd .tmp && ./main
|
cd .tmp && ./main
|
||||||
@rm -rf .tmp/main
|
rm -rf .tmp/main
|
||||||
@if [ "${RNRS}" = "r6rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -A libs main.sps; fi
|
if [ "${RNRS}" = "r6rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -A libs main.sps; fi
|
||||||
@if [ "${RNRS}" = "r7rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -A libs main.scm; fi
|
if [ "${RNRS}" = "r7rs" ]; then cd .tmp && COMPILE_R7RS=${SCHEME} sh ../compile-r7rs -o main -A libs main.scm; fi
|
||||||
@cd .tmp && ./main
|
cd .tmp && ./main
|
||||||
|
|
||||||
test-docker:
|
test-docker:
|
||||||
docker build --build-arg IMAGE=${IMAGE} --build-arg SCHEME=${SCHEME} -f Dockerfile.test --tag=${SCHEME}-testing .
|
docker build --build-arg IMAGE=${IMAGE} --build-arg SCHEME=${SCHEME} -f Dockerfile.test --tag=${SCHEME}-testing .
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue