Skip to content
Snippets Groups Projects
This project is mirrored from https://:*****@github.com/Ensembl/ensembl.git. Pull mirroring failed .
Repository mirroring has been paused due to too many failed attempts. It can be resumed by a project maintainer or owner.
Last successful update .
  1. Oct 31, 2019
  2. Oct 21, 2019
  3. Oct 18, 2019
  4. Oct 16, 2019
  5. Oct 15, 2019
  6. Sep 26, 2019
  7. Sep 18, 2019
  8. Sep 17, 2019
  9. Sep 16, 2019
  10. Sep 11, 2019
  11. Sep 03, 2019
  12. Aug 30, 2019
  13. Aug 29, 2019
  14. Aug 28, 2019
  15. Aug 23, 2019
    • Marek Szuba's avatar
      Add an inactive proof-of-concept GitLab-CI config file · aedc6218
      Marek Szuba authored
      (in case it isn't obvious, it has been deactivated by inserting
      '.inactive' into the correct file name)
      
      Unlike Ubuntu-based Travis builds, on GitLab-CI we use official Perl
      images from Docker Hub. These are Debian-based so no major changes have
      been required, support both perl-5.14 and perl-5.26 without any fuss
      (and even if they eventually removed images for some version we could
      always grab their relevant Dockerfiles and rebuild them ourselves), and
      since they only contain core Perl they give us better control over our
      dependency trees (i.e. much less risk of forgetting to add a non-core
      module to cpanfile because it was already there as distro package on the
      developer's machine).
      
      What works:
       - the test suite runs and passes for both perl-5.14/sqlite and
         perl-5.26/mysql.
      
      What still needs to be done to achieve full feature parity with Travis
      builds:
       - enable Coveralls checks for 5.26/mysql jobs. Should work in theory but
         would require adjusting coveralls.io configuration to accept reports
         from EBI GitLab;
       - trigger dependent builds. According to GitLab-CI documentation this
         is quite simple to do but unsurprisingly, the relevant GitLab API
         differs from its Travis counterpart so we cannot simply re-use the
         existing script. Besides, for the time being we do not mirror any of
         the dependent repos on EBI GitLab;
       - disable API version checks in non-release builds. Left out on purpose
         because we might have the whole of Ensembl officially adopt the
         early-version-bump policy by the time this is put into use.
      
      Does not have to be implemented in GitLab-CI:
       - configuration of e-mail and Slack notifications - in GitLab this is
         done in projects, not at CI level.
      
      What could be done even though it isn't done in Travis:
       - create our own build images with all the common dependencies already
         installed. GitLab repositories can function as Docker-compatible
         container registries so it is quite simple to create a new repo with
         this feature enabled, shove a couple of Dockerfiles into it which
         install the necessary common dependencies onto base Perl images, and
         set up CI for that repo so that the base images are periodically
         rebuilt in order to account for possible updates. Result: simpler
         API-level CI configuration, faster runs, less bandwidth wasted;
       - process cpanfiles in ensembl-io and ensembl-variation. These are
         problematic for two reasons:
          * both depend on Bio::DB::BigFile, which requires messing
            with Kent libraries and linker flags in order to work properly,
          * ensembl-variation depends on Bio::DB::HTS, which pulls in BioPerl,
            which unless explicitly instrumented to install in minimal mode
            depends on known-to-be-broken GD module.
         At present we get away with not processing them because unlike
         ensembl-compara (which luckily does not demand any difficult
         modules), Core unit tests depending on -io and -variation code only
         import modules which do not use either of the above. This of course
         is a lucky co-incidence and cannot be relied upon to last.
         We have already got scripts for dealing with both Bio::DB::BigFile
         and GD, in Otter for instance, so we could in principle address this
         right away. Then again, in my opinion it would be better to delegate
         this to the aforementioned custom build images and keep
         repository-specific CI scripting as lean as possible;
       - setting passwords for MySQL users. Trivial to do but in order to
         avoid having those passwords in plain text in .gitlab-ci.yml, we
         should either set them as GitLab project variables or encrypt them
         somehow.
      aedc6218
  16. Aug 22, 2019
    • Marek Szuba's avatar
      Patch non-core test databases to schema version 99 · 3ed0732e
      Marek Szuba authored
      1. I must have set a branch wrong or something like that for the
         previous patching because it didn't update the version of the ontology
         schema. Fixed;
      2. There is now an official variation schema-version patch;
      3. For consistency between compara test DBs (officially still at 98) and
         all the rest (officially all at 99 now), apply the same unofficial
         compara schema-version patch as in ensembl-rest.
      3ed0732e
    • Marek Szuba's avatar
      cpanfile: require Try::Tiny · a27e3930
      Marek Szuba authored
      It is used by Bio::EnsEMBL::Feature and it is not a core module.
      The reason Travis has not caught it seems to be that it comes with the
      Perl installations they provide.
      a27e3930
  17. Aug 21, 2019
  18. Aug 12, 2019
  19. Aug 08, 2019
    • Marek Szuba's avatar
      Copy PerlCritic configuration from ensembl-xref · 320e5528
      Marek Szuba authored
      More strict default severity, handle some Core-specific exceptions,
      link to PerlTidy configuration for more accurate determination whether
      the code is tidy or not, configure colours of output. Note that the
      purpose of setting default severity to 1 is merely to err on the side of
      caution in the event of severity not having been explicitly requested,
      the guideline as adopted by the Core team in December 2018 remains
      "level 4 for modified old code, level 3 for new code".
      housekeeping_perlCritic.t is not affected either because it explictly
      requests severity 5.
      320e5528
    • Marek Szuba's avatar
      Rename perlcriticrc and perltidyrc to dotfiles · c46316d5
      Marek Szuba authored
      That way they are automatically picked up by the relevant tools when run
      interactively in subdirectories of ensembl/
      c46316d5
  20. Jul 26, 2019
  21. Jul 25, 2019
    • Marek Szuba's avatar
      ChecksumParser: add a comment about read-only input paths · 0f02729d
      Marek Szuba authored
      See ENSCORESW-3197. Have to think about the correct way of specifying
      where to put that output file though, especially given the parser
      doesn't actually delete it after it is done with it.
      0f02729d
    • Marek Szuba's avatar
    • Marek Szuba's avatar
      ChecksumParser: increment checksum_xref_id BEFORE use · 41aa26b1
      Marek Szuba authored
      The initial value of the variable $counter is set to the highest
      checksum_xref.checksum_xref_id found if the table in question is not
      empty, or 0 if it is. This causes problems if $counter is only
      incremented after each use in the input-file loop:
       - for a non-empty table the parser would attempt to re-use an existing
         value of checksum_xref_id for the first entry read from the input
         file. checksum_xref_id is the primary key of checksum_xref so its
         values have to be unique, therefore "LOAD DATA" silently discards the
         offending row;
       - for an empty table we lose one input row as well but it is the SECOND
         rather than the first one. Reason: 0 is not a valid value for
         auto_increment fields in MySQL, resulting in the first row being
         inserted with the first allowed ID value of 1 - which brings us back
         to the previous scenario when "LOAD DATA" attempts to insert the
         second row.
      
      Incrementing $counter before use ought to address both forms of the
      problem.
      41aa26b1