forked from dune-universe/opam-overlays
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a test suite for continuous integration (dune-universe#180)
- Loading branch information
Showing
15 changed files
with
280 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
name: CI | ||
|
||
on: | ||
push: | ||
branches: [ master ] | ||
pull_request: | ||
branches: [ master ] | ||
|
||
jobs: | ||
test: | ||
name: Test | ||
|
||
strategy: | ||
matrix: | ||
ocaml-compiler: | ||
- 4.08.x | ||
- 4.14.x | ||
- 5.0.x | ||
|
||
steps: | ||
- name: Checkout code | ||
uses: actions/checkout@v2 | ||
|
||
- name: Use OCaml ${{ matrix.ocaml-compiler }} | ||
uses: ocaml/setup-ocaml@v2 | ||
with: | ||
ocaml-compiler: ${{ matrix.ocaml-compiler }} | ||
|
||
- name: Clone opam-repository | ||
run: git clone https://github.com/ocaml/opam-repository.git | ||
working-directory: ./test | ||
|
||
- name: Install opam dependencies | ||
run: opam install --deps-only --with-test . | ||
working-directory: ./test | ||
|
||
- name: Run tests | ||
run: opam exec -- dune test | ||
working-directory: ./test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# Local opam switch | ||
_opam | ||
|
||
# Dune build directory | ||
_build | ||
|
||
# Local copy of opam-repository | ||
opam-repository |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
(cram | ||
(applies_to :whole_subtree) | ||
(deps | ||
%{bin:opam-monorepo} | ||
(source_tree opam-repository) | ||
(source_tree opam-overlays) | ||
(sandbox preserve_file_kind))) | ||
|
||
(data_only_dirs opam-repository opam-overlays) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
(lang dune 3.0) | ||
|
||
(name opam-overlays-test) | ||
|
||
(generate_opam_files true) | ||
|
||
(cram enable) | ||
|
||
(package | ||
(name opam-overlays-test) | ||
(synopsis "CI tests for the opam-overlays repository") | ||
(description "CI tests for the opam-overlays repository") | ||
(allow_empty) | ||
(depends opam-monorepo)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
(lang dune 3.0) | ||
(name opam-overlays-test-irmin) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
opam-version: "2.0" | ||
depends: [ | ||
"irmin-bench" | ||
"irmin-chunk" | ||
"irmin-cli" | ||
"irmin-containers" | ||
"irmin-fs" | ||
"irmin-git" | ||
"irmin-graphql" | ||
"irmin-http" | ||
"irmin-mirage-git" | ||
"irmin-mirage-graphql" | ||
"irmin-mirage" | ||
"irmin-pack" | ||
"irmin-test" | ||
"irmin-tezos-utils" | ||
"irmin-tezos" | ||
"irmin" | ||
"libirmin" | ||
] | ||
x-opam-monorepo-opam-repositories: [ | ||
"file://$OPAM_MONOREPO_CWD/../opam-repository" | ||
"file://$OPAM_MONOREPO_CWD/../opam-overlays" | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
Test that opam-monorepo can generate a lockfile and build irmin. | ||
|
||
$ opam-monorepo lock > /dev/null 2>&1 | ||
opam-monorepo: [WARNING] The following packages come from the same repository git+https://github.com/mirage/ocaml-git.git but are associated with different URLs: | ||
git-unix.3.11.0: https://github.com/mirage/ocaml-git/releases/download/3.11.0/git-3.11.0.tbz | ||
git-paf.3.11.0: https://github.com/mirage/ocaml-git/releases/download/3.11.0/git-3.11.0.tbz | ||
git-mirage.3.11.0: https://github.com/mirage/ocaml-git/releases/download/3.11.0/git-3.11.0.tbz | ||
git.3.11.0: https://github.com/mirage/ocaml-git/releases/download/3.11.0/git-3.11.0.tbz | ||
carton-lwt.0.6.0: https://github.com/mirage/ocaml-git/releases/download/carton-v0.6.0/git-carton-v0.6.0.tbz | ||
carton-git.0.6.0: https://github.com/mirage/ocaml-git/releases/download/carton-v0.6.0/git-carton-v0.6.0.tbz | ||
carton.0.6.0: https://github.com/mirage/ocaml-git/releases/download/carton-v0.6.0/git-carton-v0.6.0.tbz | ||
The url for the highest versioned package was selected: git-unix.3.11.0: https://github.com/mirage/ocaml-git/releases/download/3.11.0/git-3.11.0.tbz | ||
$ opam-monorepo pull > /dev/null | ||
$ dune build | ||
$ dune exec irmin -- --version > /dev/null 2>&1 | ||
Creating menhirLib.ml... | ||
Creating menhirLib.mli... | ||
clang: warning: argument unused during compilation: '-mpopcnt' [-Wunused-command-line-argument] | ||
clang: warning: argument unused during compilation: '-mpopcnt' [-Wunused-command-line-argument] | ||
clang: warning: argument unused during compilation: '-mpopcnt' [-Wunused-command-line-argument] | ||
clang: warning: argument unused during compilation: '-mpopcnt' [-Wunused-command-line-argument] | ||
unix_tcgetattr_job.c:37:43: warning: passing 'volatile value *' (aka 'volatile long *') to parameter of type 'value *' (aka 'long *') discards qualifiers [-Wincompatible-pointer-types-discards-qualifiers] | ||
encode_terminal_status(&job->termios, &Field(res, 0)); | ||
^~~~~~~~~~~~~~ | ||
./unix_termios_conversion.h:27:69: note: passing argument to parameter 'dst' here | ||
void encode_terminal_status(struct termios *terminal_status, value *dst); | ||
^ | ||
1 warning generated. | ||
unix_tcsetattr_job.c:59:27: warning: passing 'volatile value *' (aka 'volatile long *') to parameter of type 'const void *' discards qualifiers [-Wincompatible-pointer-types-discards-qualifiers] | ||
memcpy(&job->termios, &Field(termios, 0), NFIELDS * sizeof(value)); | ||
~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/secure/_string.h:63:33: note: expanded from macro 'memcpy' | ||
__builtin___memcpy_chk (dest, __VA_ARGS__, __darwin_obsz0 (dest)) | ||
^~~~~~~~~~~ | ||
1 warning generated. | ||
Generating assets.ml | ||
Skipping generation of .mli | ||
extract-from-certdata: [WARNING] Untrusted certificate "Explicitly Distrust DigiNotar Root CA" (serial 02100fffffffffffffffffffffffffffffff) | ||
yaml_stubs.c:11:10: warning: initializing 'char *' with an expression of type 'const char *' discards qualifiers [-Wincompatible-pointer-types-discards-qualifiers] | ||
char* x2 = yaml_get_version_string(); | ||
^ ~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
yaml_stubs.c:46:38: warning: passing 'char *' to parameter of type 'const unsigned char *' converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_parser_set_input_string(x22, x23, x24); | ||
^~~ | ||
../../vendor/yaml.h:1348:30: note: passing argument to parameter 'input' here | ||
const unsigned char *input, size_t size); | ||
^ | ||
yaml_stubs.c:165:49: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
int x127 = yaml_alias_event_initialize(x125, x126); | ||
^~~~ | ||
../../vendor/yaml.h:555:69: note: passing argument to parameter 'anchor' here | ||
yaml_alias_event_initialize(yaml_event_t *event, const yaml_char_t *anchor); | ||
^ | ||
yaml_stubs.c:182:39: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_scalar_event_initialize(x136, x137, x138, x139, x140, x143, x146, | ||
^~~~ | ||
../../vendor/yaml.h:581:28: note: passing argument to parameter 'anchor' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, | ||
^ | ||
yaml_stubs.c:182:45: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_scalar_event_initialize(x136, x137, x138, x139, x140, x143, x146, | ||
^~~~ | ||
../../vendor/yaml.h:581:55: note: passing argument to parameter 'tag' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, | ||
^ | ||
yaml_stubs.c:182:51: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_scalar_event_initialize(x136, x137, x138, x139, x140, x143, x146, | ||
^~~~ | ||
../../vendor/yaml.h:582:28: note: passing argument to parameter 'value' here | ||
const yaml_char_t *value, int length, | ||
^ | ||
yaml_stubs.c:212:47: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_sequence_start_event_initialize(x166, x167, x168, x169, x172); | ||
^~~~ | ||
../../vendor/yaml.h:604:28: note: passing argument to parameter 'anchor' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, int implicit, | ||
^ | ||
yaml_stubs.c:212:53: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_sequence_start_event_initialize(x166, x167, x168, x169, x172); | ||
^~~~ | ||
../../vendor/yaml.h:604:55: note: passing argument to parameter 'tag' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, int implicit, | ||
^ | ||
yaml_stubs.c:233:46: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_mapping_start_event_initialize(x184, x185, x186, x187, x190); | ||
^~~~ | ||
../../vendor/yaml.h:636:28: note: passing argument to parameter 'anchor' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, int implicit, | ||
^ | ||
yaml_stubs.c:233:52: warning: passing 'char *' to parameter of type 'const yaml_char_t *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
yaml_mapping_start_event_initialize(x184, x185, x186, x187, x190); | ||
^~~~ | ||
../../vendor/yaml.h:636:55: note: passing argument to parameter 'tag' here | ||
const yaml_char_t *anchor, const yaml_char_t *tag, int implicit, | ||
^ | ||
10 warnings generated. | ||
duniverse/ocaml-cf/lib_gen/cf_stubs.c:44:40: warning: passing 'unsigned char *' to parameter of type 'char *' converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
_Bool x42 = CFStringGetCString(x34, x35, x36, x39); | ||
^~~ | ||
/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/System/Library/Frameworks/CoreFoundation.framework/Headers/CFString.h:329:57: note: passing argument to parameter 'buffer' here | ||
Boolean CFStringGetCString(CFStringRef theString, char *buffer, CFIndex bufferSize, CFStringEncoding encoding); | ||
^ | ||
duniverse/ocaml-cf/lib_gen/cf_stubs.c:126:51: warning: passing 'char *' to parameter of type 'UInt8 *' (aka 'unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
CFStringGetBytes(x134, x137, x138, x141, x144, x147, x148, x151); | ||
^~~~ | ||
/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/System/Library/Frameworks/CoreFoundation.framework/Headers/CFString.h:362:148: note: passing argument to parameter 'buffer' here | ||
CFIndex CFStringGetBytes(CFStringRef theString, CFRange range, CFStringEncoding encoding, UInt8 lossByte, Boolean isExternalRepresentation, UInt8 *buffer, CFIndex maxBufLen, CFIndex *usedBufLen); | ||
^ | ||
duniverse/ocaml-cf/lib_gen/cf_stubs.c:162:53: warning: passing 'char *' to parameter of type 'const UInt8 *' (aka 'const unsigned char *') converts between pointers to integer types where one is of the unique plain 'char' type and the other is not [-Wpointer-sign] | ||
CFStringRef x194 = CFStringCreateWithBytes(x183, x184, x185, x188, x191); | ||
^~~~ | ||
/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/System/Library/Frameworks/CoreFoundation.framework/Headers/CFString.h:227:72: note: passing argument to parameter 'bytes' here | ||
CFStringRef CFStringCreateWithBytes(CFAllocatorRef alloc, const UInt8 *bytes, CFIndex numBytes, CFStringEncoding encoding, Boolean isExternalRepresentation); | ||
^ | ||
3 warnings generated. | ||
Read 101 sample input sentences and 101 error messages. | ||
Read 101 sample input sentences and 48 error messages. | ||
Grammar has 56 nonterminal symbols, among which 1 start symbols. | ||
Grammar has 37 terminal symbols. | ||
Grammar has 129 productions. | ||
Built an LR(0) automaton with 194 states. | ||
The grammar is not SLR(1) -- 5 states have a conflict. | ||
The construction mode is no-pager. | ||
Built an LR(1) automaton with 298 states. | ||
One shift/reduce conflict was silently solved. | ||
Extra reductions on error were added in 40 states. | ||
Priority played a role in 0 of these states. | ||
152 out of 298 states have a default reduction. | ||
102 out of 298 states are represented. | ||
44 out of 96 symbols keep track of their start position. | ||
41 out of 96 symbols keep track of their end position. | ||
264 specialized copies of 64 functions have been created. | ||
The StackLang code contains 5161 instructions in 241 blocks. | ||
The StackLang code comprises 5 mutually recursive groups. | ||
Read 101 sample input sentences and 48 error messages. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
(lang dune 3.0) | ||
(name opam-overlays-test-mdx) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
opam-version: "2.0" | ||
depends: [ | ||
"mdx" | ||
] | ||
x-opam-monorepo-opam-repositories: [ | ||
"file://$OPAM_MONOREPO_CWD/../opam-repository" | ||
"file://$OPAM_MONOREPO_CWD/../opam-overlays" | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
Test that opam-monorepo can generate a lockfile and build mdx. | ||
|
||
$ opam-monorepo lock > /dev/null | ||
$ opam-monorepo pull > /dev/null | ||
$ dune build | ||
$ dune exec ocaml-mdx -- --version > /dev/null |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# This file is generated by dune, edit dune-project instead | ||
opam-version: "2.0" | ||
synopsis: "CI tests for the opam-overlays repository" | ||
description: "CI tests for the opam-overlays repository" | ||
depends: [ | ||
"dune" {>= "3.0"} | ||
"opam-monorepo" | ||
"odoc" {with-doc} | ||
] | ||
build: [ | ||
["dune" "subst"] {dev} | ||
[ | ||
"dune" | ||
"build" | ||
"-p" | ||
name | ||
"-j" | ||
jobs | ||
"@install" | ||
"@runtest" {with-test} | ||
"@doc" {with-doc} | ||
] | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
../../packages/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
opam-version: "2.0" |
Submodule book
added at
0f8ea6
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
Test that opam-monorepo can generate a lockfile Real World OCaml. | ||
We're not building it because it's not ported to OCaml 5 yet. | ||
|
||
$ if [ ! -d book/ ]; then git clone https://github.com/realworldocaml/book.git; fi > /dev/null | ||
$ rm ../../../.git | ||
$ cd book && opam-monorepo lock --opam-repositories='[file://$OPAM_MONOREPO_CWD/../../opam-repository,file://$OPAM_MONOREPO_CWD/../../opam-overlays]' > /dev/null | ||
$ opam-monorepo pull > /dev/null |