.travis.yml 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. # Environment variables
  2. env:
  3. global:
  4. - CFLAGS=-Werror
  5. # Common test script
  6. script:
  7. # make sure example can at least compile
  8. - sed -n '/``` c/,/```/{/```/d; p;}' README.md > test.c &&
  9. make all CFLAGS+="
  10. -Duser_provided_block_device_read=NULL
  11. -Duser_provided_block_device_prog=NULL
  12. -Duser_provided_block_device_erase=NULL
  13. -Duser_provided_block_device_sync=NULL
  14. -include stdio.h"
  15. # run tests
  16. - make test QUIET=1
  17. # run tests with a few different configurations
  18. - make test QUIET=1 CFLAGS+="-DLFS_READ_SIZE=1 -DLFS_CACHE_SIZE=4"
  19. - make test QUIET=1 CFLAGS+="-DLFS_READ_SIZE=512 -DLFS_CACHE_SIZE=512 -DLFS_BLOCK_CYCLES=16"
  20. - make test QUIET=1 CFLAGS+="-DLFS_BLOCK_COUNT=1023 -DLFS_LOOKAHEAD_SIZE=256"
  21. - make clean test QUIET=1 CFLAGS+="-DLFS_INLINE_MAX=0"
  22. - make clean test QUIET=1 CFLAGS+="-DLFS_NO_INTRINSICS"
  23. # compile and find the code size with the smallest configuration
  24. - make clean size
  25. OBJ="$(ls lfs*.o | tr '\n' ' ')"
  26. CFLAGS+="-DLFS_NO_ASSERT -DLFS_NO_DEBUG -DLFS_NO_WARN -DLFS_NO_ERROR"
  27. | tee sizes
  28. # update status if we succeeded, compare with master if possible
  29. - |
  30. if [ "$TRAVIS_TEST_RESULT" -eq 0 ]
  31. then
  32. CURR=$(tail -n1 sizes | awk '{print $1}')
  33. PREV=$(curl -u $GEKY_BOT_STATUSES https://api.github.com/repos/$TRAVIS_REPO_SLUG/status/master \
  34. | jq -re "select(.sha != \"$TRAVIS_COMMIT\")
  35. | .statuses[] | select(.context == \"$STAGE/$NAME\").description
  36. | capture(\"code size is (?<size>[0-9]+)\").size" \
  37. || echo 0)
  38. STATUS="Passed, code size is ${CURR}B"
  39. if [ "$PREV" -ne 0 ]
  40. then
  41. STATUS="$STATUS ($(python -c "print '%+.2f' % (100*($CURR-$PREV)/$PREV.0)")%)"
  42. fi
  43. fi
  44. # CI matrix
  45. jobs:
  46. include:
  47. # native testing
  48. - stage: test
  49. env:
  50. - STAGE=test
  51. - NAME=littlefs-x86
  52. # cross-compile with ARM (thumb mode)
  53. - stage: test
  54. env:
  55. - STAGE=test
  56. - NAME=littlefs-arm
  57. - CC="arm-linux-gnueabi-gcc --static -mthumb"
  58. - EXEC="qemu-arm"
  59. install:
  60. - sudo apt-get install gcc-arm-linux-gnueabi qemu-user
  61. - arm-linux-gnueabi-gcc --version
  62. - qemu-arm -version
  63. # cross-compile with PowerPC
  64. - stage: test
  65. env:
  66. - STAGE=test
  67. - NAME=littlefs-powerpc
  68. - CC="powerpc-linux-gnu-gcc --static"
  69. - EXEC="qemu-ppc"
  70. install:
  71. - sudo apt-get install gcc-powerpc-linux-gnu qemu-user
  72. - powerpc-linux-gnu-gcc --version
  73. - qemu-ppc -version
  74. # cross-compile with MIPS
  75. - stage: test
  76. env:
  77. - STAGE=test
  78. - NAME=littlefs-mips
  79. - CC="mips-linux-gnu-gcc --static"
  80. - EXEC="qemu-mips"
  81. install:
  82. - sudo add-apt-repository -y "deb http://archive.ubuntu.com/ubuntu/ xenial main universe"
  83. - sudo apt-get -qq update
  84. - sudo apt-get install gcc-mips-linux-gnu qemu-user
  85. - mips-linux-gnu-gcc --version
  86. - qemu-mips -version
  87. # self-host with littlefs-fuse for fuzz test
  88. - stage: test
  89. env:
  90. - STAGE=test
  91. - NAME=littlefs-fuse
  92. install:
  93. - sudo apt-get install libfuse-dev
  94. - git clone --depth 1 https://github.com/geky/littlefs-fuse -b v2-alpha
  95. - fusermount -V
  96. - gcc --version
  97. before_script:
  98. # setup disk for littlefs-fuse
  99. - rm -rf littlefs-fuse/littlefs/*
  100. - cp -r $(git ls-tree --name-only HEAD) littlefs-fuse/littlefs
  101. - mkdir mount
  102. - sudo chmod a+rw /dev/loop0
  103. - dd if=/dev/zero bs=512 count=4096 of=disk
  104. - losetup /dev/loop0 disk
  105. script:
  106. # self-host test
  107. - make -C littlefs-fuse
  108. - littlefs-fuse/lfs --format /dev/loop0
  109. - littlefs-fuse/lfs /dev/loop0 mount
  110. - ls mount
  111. - mkdir mount/littlefs
  112. - cp -r $(git ls-tree --name-only HEAD) mount/littlefs
  113. - cd mount/littlefs
  114. - stat .
  115. - ls -flh
  116. - make -B test_dirs test_files QUIET=1
  117. # self-host with littlefs-fuse for fuzz test
  118. - stage: test
  119. env:
  120. - STAGE=test
  121. - NAME=littlefs-migration
  122. install:
  123. - sudo apt-get install libfuse-dev
  124. - git clone --depth 1 https://github.com/geky/littlefs-fuse -b v2-alpha v2
  125. - git clone --depth 1 https://github.com/geky/littlefs-fuse v1
  126. - fusermount -V
  127. - gcc --version
  128. before_script:
  129. # setup disk for littlefs-fuse
  130. - rm -rf v2/littlefs/*
  131. - cp -r $(git ls-tree --name-only HEAD) v2/littlefs
  132. - mkdir mount
  133. - sudo chmod a+rw /dev/loop0
  134. - dd if=/dev/zero bs=512 count=4096 of=disk
  135. - losetup /dev/loop0 disk
  136. script:
  137. # compile v1 and v2
  138. - make -C v1
  139. - make -C v2
  140. # run self-host test with v1
  141. - v1/lfs --format /dev/loop0
  142. - v1/lfs /dev/loop0 mount
  143. - ls mount
  144. - mkdir mount/littlefs
  145. - cp -r $(git ls-tree --name-only HEAD) mount/littlefs
  146. - cd mount/littlefs
  147. - stat .
  148. - ls -flh
  149. - make -B test_dirs test_files QUIET=1
  150. # attempt to migrate
  151. - cd ../..
  152. - fusermount -u mount
  153. - v2/lfs --migrate /dev/loop0
  154. - v2/lfs /dev/loop0 mount
  155. # run self-host test with v2 right where we left off
  156. - ls mount
  157. - cd mount/littlefs
  158. - stat .
  159. - ls -flh
  160. - make -B test_dirs test_files QUIET=1
  161. # Automatically create releases
  162. - stage: deploy
  163. env:
  164. - STAGE=deploy
  165. - NAME=deploy
  166. script:
  167. # Find version defined in lfs.h
  168. - LFS_VERSION=$(grep -ox '#define LFS_VERSION .*' lfs.h | cut -d ' ' -f3)
  169. - LFS_VERSION_MAJOR=$((0xffff & ($LFS_VERSION >> 16)))
  170. - LFS_VERSION_MINOR=$((0xffff & ($LFS_VERSION >> 0)))
  171. # Grab latests patch from repo tags, default to 0, needs finagling to get past github's pagination api
  172. - PREV_URL=https://api.github.com/repos/$TRAVIS_REPO_SLUG/git/refs/tags/v$LFS_VERSION_MAJOR.$LFS_VERSION_MINOR.
  173. - PREV_URL=$(curl -u "$GEKY_BOT_RELEASES" "$PREV_URL" -I
  174. | sed -n '/^Link/{s/.*<\(.*\)>; rel="last"/\1/;p;q0};$q1'
  175. || echo $PREV_URL)
  176. - LFS_VERSION_PATCH=$(curl -u "$GEKY_BOT_RELEASES" "$PREV_URL"
  177. | jq 'map(.ref | match("\\bv.*\\..*\\.(.*)$";"g")
  178. .captures[].string | tonumber) | max + 1'
  179. || echo 0)
  180. # We have our new version
  181. - LFS_VERSION="v$LFS_VERSION_MAJOR.$LFS_VERSION_MINOR.$LFS_VERSION_PATCH"
  182. - echo "VERSION $LFS_VERSION"
  183. - |
  184. # Check that we're the most recent commit
  185. CURRENT_COMMIT=$(curl -f -u "$GEKY_BOT_RELEASES" \
  186. https://api.github.com/repos/$TRAVIS_REPO_SLUG/commits/master \
  187. | jq -re '.sha')
  188. if [ "$TRAVIS_COMMIT" == "$CURRENT_COMMIT" ]
  189. then
  190. # Create a simple tag
  191. curl -f -u "$GEKY_BOT_RELEASES" -X POST \
  192. https://api.github.com/repos/$TRAVIS_REPO_SLUG/git/refs \
  193. -d "{
  194. \"ref\": \"refs/tags/$LFS_VERSION\",
  195. \"sha\": \"$TRAVIS_COMMIT\"
  196. }"
  197. # Minor release?
  198. if [[ "$LFS_VERSION" == *.0 ]]
  199. then
  200. # Build release notes
  201. PREV=$(git tag --sort=-v:refname -l "v*.0" | head -1)
  202. if [ ! -z "$PREV" ]
  203. then
  204. echo "PREV $PREV"
  205. CHANGES=$'### Changes\n\n'$( \
  206. git log --oneline $PREV.. --grep='^Merge' --invert-grep)
  207. printf "CHANGES\n%s\n\n" "$CHANGES"
  208. fi
  209. # Create the release
  210. curl -f -u "$GEKY_BOT_RELEASES" -X POST \
  211. https://api.github.com/repos/$TRAVIS_REPO_SLUG/releases \
  212. -d "{
  213. \"tag_name\": \"$LFS_VERSION\",
  214. \"name\": \"${LFS_VERSION%.0}\",
  215. \"draft\": true,
  216. \"body\": $(jq -sR '.' <<< "$CHANGES")
  217. }"
  218. fi
  219. fi
  220. # Manage statuses
  221. before_install:
  222. - |
  223. curl -u $GEKY_BOT_STATUSES -X POST \
  224. https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
  225. -d "{
  226. \"context\": \"$STAGE/$NAME\",
  227. \"state\": \"pending\",
  228. \"description\": \"${STATUS:-In progress}\",
  229. \"target_url\": \"https://travis-ci.org/$TRAVIS_REPO_SLUG/jobs/$TRAVIS_JOB_ID\"
  230. }"
  231. after_failure:
  232. - |
  233. curl -u $GEKY_BOT_STATUSES -X POST \
  234. https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
  235. -d "{
  236. \"context\": \"$STAGE/$NAME\",
  237. \"state\": \"failure\",
  238. \"description\": \"${STATUS:-Failed}\",
  239. \"target_url\": \"https://travis-ci.org/$TRAVIS_REPO_SLUG/jobs/$TRAVIS_JOB_ID\"
  240. }"
  241. after_success:
  242. - |
  243. curl -u $GEKY_BOT_STATUSES -X POST \
  244. https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
  245. -d "{
  246. \"context\": \"$STAGE/$NAME\",
  247. \"state\": \"success\",
  248. \"description\": \"${STATUS:-Passed}\",
  249. \"target_url\": \"https://travis-ci.org/$TRAVIS_REPO_SLUG/jobs/$TRAVIS_JOB_ID\"
  250. }"
  251. # Job control
  252. stages:
  253. - name: test
  254. - name: deploy
  255. if: branch = master AND type = push