Use Fedora for the CI pipeline.

This commit is contained in:
Jason S. Ninneman 2017-07-14 20:45:19 -07:00 committed by NHOrus
parent f46d5de108
commit add623548f
3 changed files with 35 additions and 46 deletions

View file

@ -1,4 +1,4 @@
image: alpine image: fedora
stages: stages:
- build - build
@ -9,44 +9,36 @@ stages:
binary:debug: binary:debug:
stage: build stage: build
before_script: before_script:
- apk update - dnf install make gcc libedit-devel libasan libubsan python2 PyYAML lcov -y
- apk add make gcc musl-dev python py2-pip libedit-dev
- pip install PyYAML
script: script:
- make debug - make debug
artifacts: artifacts:
paths: paths:
- advent - advent
- cheat - cheat
- "*.gcda"
- "*.gcno"
# cache outputs to reduce the build time
cache:
paths:
- "*.o" - "*.o"
- dungeon.c
- dungeon.h
- "*.gcno"
binary:release: binary:release:
stage: build stage: build
before_script: before_script:
- apk update - dnf install make gcc libedit-devel python2 PyYAML -y
- apk add make gcc musl-dev python py2-pip libedit-dev
- pip install PyYAML
script: script:
- make advent cheat - make advent cheat
artifacts: artifacts:
paths: paths:
- advent - advent
- cheat - cheat
# cache outputs to reduce the build time
cache:
paths:
- "*.o" - "*.o"
- dungeon.c
- dungeon.h
manpage: manpage:
stage: build stage: build
before_script: before_script:
- apk update - dnf install make asciidoc -y
- apk add make asciidoc
script: script:
- make advent.6 - make advent.6
artifacts: artifacts:
@ -56,8 +48,7 @@ manpage:
html: html:
stage: build stage: build
before_script: before_script:
- apk update - dnf install make asciidoc libxslt -y
- apk add make asciidoc libxslt
script: script:
- make html - make html
artifacts: artifacts:
@ -67,8 +58,7 @@ html:
dist: dist:
stage: build stage: build
before_script: before_script:
- apk update - dnf install make asciidoc -y
- apk add make asciidoc
script: script:
- export VERS=${CI_COMMIT_REF_NAME} - export VERS=${CI_COMMIT_REF_NAME}
- make dist -e - make dist -e
@ -80,26 +70,23 @@ dist:
test:debug: test:debug:
stage: test stage: test
before_script: before_script:
- apk update - dnf install make gcc libedit-devel libasan libubsan python2 PyYAML lcov -y
- apk add make gcc python py2-pip libedit-dev
- pip install PyYAML
- apk add lcov --update-cache --repository http://dl-3.alpinelinux.org/alpine/edge/testing/ --allow-untrusted
script: script:
- make debug
- make check
- lcov -t "advent" -o advent.info -c -d .
- genhtml -o coverage advent.info
- cd tests - cd tests
- make - ./coverage_dungeon.py
- make coverage
- cd .. - cd ..
artifacts: artifacts:
paths: paths:
- coverage - coverage
dependencies:
- binary:debug
test:release: test:release:
stage: test stage: test
before_script: before_script:
- apk update - dnf install make libedit -y
- apk add make libedit
script: script:
- cd tests - cd tests
- make - make

View file

@ -58,7 +58,7 @@ cheat: $(CHEAT_OBJS) dungeon.o
check: advent cheat check: advent cheat
cd tests; $(MAKE) --quiet cd tests; $(MAKE) --quiet
coverage: debug cheat coverage: debug
cd tests; $(MAKE) coverage --quiet cd tests; $(MAKE) coverage --quiet
.SUFFIXES: .adoc .html .6 .SUFFIXES: .adoc .html .6

View file

@ -3,7 +3,8 @@
# Use absolute path so tests that change working directory still use # Use absolute path so tests that change working directory still use
# scripts from parent directory. Note that using $PWD seems to fail # scripts from parent directory. Note that using $PWD seems to fail
# here under Gitlab's CI environment. # here under Gitlab's CI environment.
PATH := $(realpath ..):$(realpath .):${PATH} PARDIR=$(realpath ..)
PATH := $(PARDIR):$(realpath .):${PATH}
GCOV?=gcov GCOV?=gcov
# Make this overrideable so it's easier to test old versions # Make this overrideable so it's easier to test old versions
@ -24,8 +25,9 @@ check: savecheck regress
@-advent -l /dev/null <pitfall.log >/dev/null @-advent -l /dev/null <pitfall.log >/dev/null
coverage: check coverage: check
lcov -t "advent" -o ../advent.info -c -d .. --gcov-tool=$(GCOV) ls -lR $(PARDIR)
genhtml -o ../coverage/ ../advent.info lcov -t "advent" -o $(PARDIR)/advent.info -c -d $(PARDIR) --gcov-tool=$(GCOV)
genhtml -o $(PARDIR)/coverage/ $(PARDIR)/advent.info
./coverage_dungeon.py ./coverage_dungeon.py
.SUFFIXES: .chk .SUFFIXES: .chk
@ -44,23 +46,23 @@ listcheck:
# Generate bogus savegames. # Generate bogus savegames.
savegames: savegames:
@$(ECHO) "cheat: Generate save file with -900 deaths" @$(ECHO) "cheat: Generate save file with -900 deaths"
@../cheat -d -900 -o cheat_numdie.adv > /tmp/cheat_numdie @$(PARDIR)/cheat -d -900 -o cheat_numdie.adv > /tmp/cheat_numdie
@$(ECHO) "cheat: Generate save file with -1000 deaths" @$(ECHO) "cheat: Generate save file with -1000 deaths"
@../cheat -d -1000 -o cheat_numdie1000.adv > /tmp/cheat_numdie1000 @$(PARDIR)/cheat -d -1000 -o cheat_numdie1000.adv > /tmp/cheat_numdie1000
@$(ECHO) "cheat: Generate save file with version -1337" @$(ECHO) "cheat: Generate save file with version -1337"
@../cheat -v -1337 -o resume_badversion.adv > /tmp/cheat_badversion @$(PARDIR)/cheat -v -1337 -o resume_badversion.adv > /tmp/cheat_badversion
@$(ECHO) "cheat: Generate save file 1000 saves" @$(ECHO) "cheat: Generate save file 1000 saves"
@../cheat -s -1000 -o thousand_saves.adv > /tmp/cheat_1000saves @$(PARDIR)/cheat -s -1000 -o thousand_saves.adv > /tmp/cheat_1000saves
@$(ECHO) "cheat: Generate save file 1000 turns" @$(ECHO) "cheat: Generate save file 1000 turns"
@../cheat -t -1000 -o thousand_saves.adv > /tmp/cheat_1000turns @$(PARDIR)/cheat -t -1000 -o thousand_saves.adv > /tmp/cheat_1000turns
@$(ECHO) "cheat: Generate save file 1000 turns" @$(ECHO) "cheat: Generate save file 1000 turns"
@../cheat -l -1000 -o thousand_lamp.adv > /tmp/cheat_1000lamp @$(PARDIR)/cheat -l -1000 -o thousand_lamp.adv > /tmp/cheat_1000lamp
@rm -f /tmp/cheat* @rm -f /tmp/cheat*
# Rebuild characterizing tests # Rebuild characterizing tests
buildregress: savegames buildregress: savegames
../cheat -s -1000 -o thousand_saves.adv > /tmp/regress1000saves $(PARDIR)/cheat -s -1000 -o thousand_saves.adv > /tmp/regress1000saves
@for file in $(TESTLOADS); do \ @for file in $(TESTLOADS); do \
echo "Remaking $${file}.chk"; \ echo "Remaking $${file}.chk"; \
OPTS=`sed -n /#options:/s///p <$${file}.log`; \ OPTS=`sed -n /#options:/s///p <$${file}.log`; \
@ -70,13 +72,13 @@ buildregress: savegames
savecheck: savegames savecheck: savegames
@$(ECHO) "TEST cheat: Bogus option for save file generation" @$(ECHO) "TEST cheat: Bogus option for save file generation"
@../cheat -QqQ 2> /tmp/coverage_cheat_batopt | true @$(PARDIR)/cheat -QqQ 2> /tmp/coverage_cheat_batopt | true
@$(ECHO) "TEST cheat: No save file specified" @$(ECHO) "TEST cheat: No save file specified"
@../cheat 2>/dev/null | true @$(PARDIR)/cheat 2>/dev/null | true
@$(ECHO) "TEST cheat: Fail to save because we omit -o" @$(ECHO) "TEST cheat: Fail to save because we omit -o"
@../cheat -d 1 2> /tmp/coverage_cheat_nooutput | true @$(PARDIR)/cheat -d 1 2> /tmp/coverage_cheat_nooutput | true
@$(ECHO) "TEST cheat: Fail to save to invalid path" @$(ECHO) "TEST cheat: Fail to save to invalid path"
@../cheat -o / 2> /tmp/coverage_cheat_badoutput | true @$(PARDIR)/cheat -o / 2> /tmp/coverage_cheat_badoutput | true
@$(ECHO) "TEST advent: Start with invalid file with -r" @$(ECHO) "TEST advent: Start with invalid file with -r"
@advent -r /badfilename < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1 @advent -r /badfilename < pitfall.log > /tmp/coverage_advent_readfail 2>&1 || exit 1
@$(ECHO) "TEST advent: Start with invalid file with -l" @$(ECHO) "TEST advent: Start with invalid file with -l"