blob: cadd975c1145e54123b9eb458d52e565a0a71c99 [file] [log] [blame]
Marc Kupietz3d82f562024-03-16 10:19:03 +01001
2stages:
3 - test
4 - build
5 - deploy
6
7variables:
8 VID: $VID
9 DEBIAN_FRONTEND: noninteractive
10 APT_CACHE_DIR: apt-cache
Marc Kupietzd320f992024-04-19 12:30:04 +020011 SRC_DIR: test/resources/DNB
Marc Kupietzfddbb512024-04-26 16:49:02 +020012 YEARS: "13 18"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020013 SAXON_HOME: "$CI_PROJECT_DIR/lib"
Marc Kupietz3d82f562024-03-16 10:19:03 +010014
15build-and-test-i5:
16 stage: test
17 image: rocker/verse
18 artifacts:
19 paths:
Marc Kupietz5b734ce2024-04-26 17:20:09 +020020 - "target/dnb??.i5.xml"
Marc Kupietz3d82f562024-03-16 10:19:03 +010021 - "target/*.zip"
22 cache:
23 - key: DNB4KorAP
24 paths:
25 - apt-cache/
26
27 before_script:
28 - source `find .. -name section_helper.sh`
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020029 - mkdir -p "$SAXON_HOME"
Marc Kupietzab37fa42025-09-25 10:55:32 +020030 - start_section saxon_license_debug "Preparing Saxon license"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020031 - |
Marc Kupietz0eb37492025-09-25 10:58:46 +020032 echo "SAXON_HOME=$SAXON_HOME"
33 echo "SAXON_LICENSE=$SAXON_LICENSE"
34 ls -l "$SAXON_HOME" || true
35 ls -l "$SAXON_LICENSE" || true
Marc Kupietz7c56da92025-09-25 10:47:20 +020036 if [ -r "$SAXON_LICENSE" ]; then
Marc Kupietz0eb37492025-09-25 10:58:46 +020037 echo "SAXON_LICENSE readable: yes"
Marc Kupietzab37fa42025-09-25 10:55:32 +020038 cp -v "$SAXON_LICENSE" "$SAXON_HOME/saxon-license.lic" && ls -l "$SAXON_HOME/saxon-license.lic"
39 else
Marc Kupietz0eb37492025-09-25 10:58:46 +020040 echo "SAXON_LICENSE readable: no"
Marc Kupietzab37fa42025-09-25 10:55:32 +020041 echo "No readable SAXON_LICENSE file variable present"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020042 fi
Marc Kupietzab37fa42025-09-25 10:55:32 +020043 - end_section saxon_license_debug
Marc Kupietz3d82f562024-03-16 10:19:03 +010044 - start_section install_linux_packages "Installing missing Linux packages"
45 - apt-get -o dir::cache::archives="$APT_CACHE_DIR" update
Marc Kupietzab0a7332024-04-26 13:25:16 +020046 - apt-get -o dir::cache::archives="$APT_CACHE_DIR" install -y libxml2-utils curl openjdk-17-jre-headless xmlstarlet
Marc Kupietz3d82f562024-03-16 10:19:03 +010047 - end_section install_linux_packages
Marc Kupietzec784c82024-04-21 17:41:00 +020048 - start_section install_models "Installing models"
49 - make models/dereko_domains_s.classifier
50 - end_section install_models
Marc Kupietz3d82f562024-03-16 10:19:03 +010051
52 script:
53 - start_section checking_i5 "Building and testing I5 files"
Marc Kupietzedce85c2024-04-26 17:17:25 +020054 - make -j $(nproc) test
Marc Kupietz3d82f562024-03-16 10:19:03 +010055 - end_section checking_i5
56
57
Marc Kupietz6d534882024-03-17 16:25:26 +010058build-index:
Marc Kupietz3d82f562024-03-16 10:19:03 +010059 image: perl:5.38
Marc Kupietzb169c272024-03-16 12:07:54 +010060 services:
61 - docker:dind
Marc Kupietz3d82f562024-03-16 10:19:03 +010062 stage: build
63 rules:
Marc Kupietzdf3aacd2024-05-09 21:55:54 +020064 - if: '$CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH && $CI_JOB_MANUAL == "true"'
Marc Kupietzf9a703b2024-05-09 21:53:32 +020065 variables:
66 VID: $CI_COMMIT_BRANCH-$CI_COMMIT_SHORT_SHA
67 PERL_LOCAL_LIB_ROOT: ./perl5
68 PERL5LIB: ./perl5/lib/perl5
Marc Kupietz3d82f562024-03-16 10:19:03 +010069 cache:
70 - key: DNB4KorAP
71 paths:
72 - $PERL_LOCAL_LIB_ROOT
73 - perl5/
74 - apt-cache/
75 - key:
76 files:
Marc Kupietz94bbe6b2024-04-10 20:35:48 +020077 - target/dnb18.i5.xml
Marc Kupietz3d82f562024-03-16 10:19:03 +010078 paths:
Marc Kupietz94bbe6b2024-04-10 20:35:48 +020079 - target/dnb18.zip
80 - target/dnb18.tree_tagger.zip
81 - target/dnb18.marmot-malt.zip
82 - target/dnb18.spacy.zip
83 - target/dnb18.krill.tar
Marc Kupietz13e28582024-04-19 11:26:01 +020084
Marc Kupietz3d82f562024-03-16 10:19:03 +010085 before_script:
86 - source `find .. -name section_helper.sh`
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020087 - mkdir -p "$SAXON_HOME"
Marc Kupietzab37fa42025-09-25 10:55:32 +020088 - start_section saxon_license_debug "Preparing Saxon license"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +020089 - |
Marc Kupietz0eb37492025-09-25 10:58:46 +020090 echo "SAXON_HOME=$SAXON_HOME"
91 echo "SAXON_LICENSE=$SAXON_LICENSE"
92 ls -l "$SAXON_HOME" || true
93 ls -l "$SAXON_LICENSE" || true
Marc Kupietz7c56da92025-09-25 10:47:20 +020094 if [ -r "$SAXON_LICENSE" ]; then
Marc Kupietz0eb37492025-09-25 10:58:46 +020095 echo "SAXON_LICENSE readable: yes"
Marc Kupietzab37fa42025-09-25 10:55:32 +020096 cp -v "$SAXON_LICENSE" "$SAXON_HOME/saxon-license.lic" && ls -l "$SAXON_HOME/saxon-license.lic"
97 else
Marc Kupietz0eb37492025-09-25 10:58:46 +020098 echo "SAXON_LICENSE readable: no"
Marc Kupietzab37fa42025-09-25 10:55:32 +020099 echo "No readable SAXON_LICENSE file variable present"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +0200100 fi
Marc Kupietzab37fa42025-09-25 10:55:32 +0200101 - end_section saxon_license_debug
Marc Kupietz3d82f562024-03-16 10:19:03 +0100102 - start_section install_linux_packages "Installing missing Linux packages"
103 - mkdir -pv $APT_CACHE_DIR
104 - apt-get -o dir::cache::archives="$APT_CACHE_DIR" update
Marc Kupietzb169c272024-03-16 12:07:54 +0100105 - apt-get -o dir::cache::archives="$APT_CACHE_DIR" install -y rsync pv jq curl openjdk-17-jre-headless docker.io
Marc Kupietz3d82f562024-03-16 10:19:03 +0100106 - end_section install_linux_packages
107
Marc Kupietzb169c272024-03-16 12:07:54 +0100108 - start_section install_tree_tagger "Installing TreeTagger"
Marc Kupietz420260d2024-03-17 19:14:10 +0100109 - docker image inspect korap/conllu2treetagger:latest >/dev/null 2>&1 || curl -Ls 'https://gitlab.ids-mannheim.de/KorAP/CoNLL-U-Treetagger/-/jobs/artifacts/master/raw/conllu2treetagger.xz?job=build-docker-image' | docker load
Marc Kupietzb169c272024-03-16 12:07:54 +0100110 - end_section install_tree_tagger
111
Marc Kupietz6d534882024-03-17 16:25:26 +0100112 - start_section install_spacy "Installing spaCy"
Marc Kupietz420260d2024-03-17 19:14:10 +0100113 - docker image inspect korap/conllu2spacy:latest >/dev/null 2>&1 || curl -Ls https://corpora.ids-mannheim.de/tools/conllu2spacy.tar.xz | docker load
Marc Kupietz6d534882024-03-17 16:25:26 +0100114 - end_section install_spacy
115
Marc Kupietz3d82f562024-03-16 10:19:03 +0100116 - start_section install_perl_packages "Installing missing Perl packages"
117 - curl -L https://cpanmin.us | perl - App::cpanminus
118 - cpanm -n -l $PERL_LOCAL_LIB_ROOT File::ShareDir::Install https://github.com/KorAP/KorAP-XML-TEI.git
Marc Kupietzf73a91d2024-04-10 20:45:42 +0200119 - cpanm -n -l $PERL_LOCAL_LIB_ROOT https://github.com/KorAP/KorAP-XML-Krill.git
120 - cpanm -n -l $PERL_LOCAL_LIB_ROOT https://github.com/KorAP/KorAP-XML-CoNLL-U.git
Marc Kupietz3d82f562024-03-16 10:19:03 +0100121 - end_section install_perl_packages
122
123 script:
124 - export PATH=$PERL_LOCAL_LIB_ROOT/bin:$PATH
Marc Kupietz6d534882024-03-17 16:25:26 +0100125 - start_section building_index "Building index"
Marc Kupietz420260d2024-03-17 19:14:10 +0100126 - touch target/*.zip # ignore timestamps in make
127 - sleep 1
Marc Kupietz48c6a682024-03-24 15:27:08 +0100128 - touch target/*.*.zip
Marc Kupietz13e28582024-04-19 11:26:01 +0200129 - MAX_THREADS=2 make -j $(nproc) target/dnb.index.tar.xz
Marc Kupietz3d82f562024-03-16 10:19:03 +0100130 - end_section building_krill
131 artifacts:
132 paths:
Marc Kupietzb169c272024-03-16 12:07:54 +0100133 - target/*.zip
Marc Kupietz94bbe6b2024-04-10 20:35:48 +0200134 - target/dnb18.index.tar.xz
Marc Kupietz3d82f562024-03-16 10:19:03 +0100135
136deploy:
137 stage: deploy
138 dependencies:
Marc Kupietz420260d2024-03-17 19:14:10 +0100139 - "build-index"
Marc Kupietz105913d2024-05-09 21:34:13 +0200140 rules:
Marc Kupietzdf3aacd2024-05-09 21:55:54 +0200141 - if: '$CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH && $CI_JOB_MANUAL == "true"'
Marc Kupietz3d82f562024-03-16 10:19:03 +0100142 image: rocker/verse
143 before_script:
144 - source `find .. -name section_helper.sh`
Marc Kupietz82e5b7b2025-09-25 09:58:29 +0200145 - mkdir -p "$SAXON_HOME"
Marc Kupietzab37fa42025-09-25 10:55:32 +0200146 - start_section saxon_license_debug "Preparing Saxon license"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +0200147 - |
Marc Kupietz0eb37492025-09-25 10:58:46 +0200148 echo "SAXON_HOME=$SAXON_HOME"
149 echo "SAXON_LICENSE=$SAXON_LICENSE"
150 ls -l "$SAXON_HOME" || true
151 ls -l "$SAXON_LICENSE" || true
Marc Kupietz7c56da92025-09-25 10:47:20 +0200152 if [ -r "$SAXON_LICENSE" ]; then
Marc Kupietz0eb37492025-09-25 10:58:46 +0200153 echo "SAXON_LICENSE readable: yes"
Marc Kupietzab37fa42025-09-25 10:55:32 +0200154 cp -v "$SAXON_LICENSE" "$SAXON_HOME/saxon-license.lic" && ls -l "$SAXON_HOME/saxon-license.lic"
155 else
Marc Kupietz0eb37492025-09-25 10:58:46 +0200156 echo "SAXON_LICENSE readable: no"
Marc Kupietzab37fa42025-09-25 10:55:32 +0200157 echo "No readable SAXON_LICENSE file variable present"
Marc Kupietz82e5b7b2025-09-25 09:58:29 +0200158 fi
Marc Kupietzab37fa42025-09-25 10:55:32 +0200159 - end_section saxon_license_debug
Marc Kupietz3d82f562024-03-16 10:19:03 +0100160 - start_section setup_ssh "Setting up SSH"
161 - apt-get update
162 - apt-get install -y rsync openssh-client
163 - mkdir -p ~/.ssh
164 - chmod 700 ~/.ssh
165 - eval $(ssh-agent -s)
166 - chmod 400 $SSH_PRIVATE_KEY
167 - ssh-add $SSH_PRIVATE_KEY
168 - end_section setup_ssh
169 script:
Marc Kupietzb7696992024-03-18 17:41:15 +0100170 - start_section korapxmlu "Uploading index to KorAP4DNB instance"
Marc Kupietz94bbe6b2024-04-10 20:35:48 +0200171 - touch target/dnb18.index.tar.xz
Marc Kupietzb7696992024-03-18 17:41:15 +0100172 - make deploy
Marc Kupietz3d82f562024-03-16 10:19:03 +0100173 - end_section deploy