From f18229c0c91a78f4b1646aae62a65b9d29a0cb89 Mon Sep 17 00:00:00 2001 From: Olivia Guyot Date: Wed, 27 Dec 2023 16:00:31 +0100 Subject: [PATCH] feat(support-services): set default pipeline before reindexing all records Also adapts datasets e2e to run without indexing again --- .github/workflows/checks.yml | 2 +- apps/datahub-e2e/src/e2e/datasets.cy.ts | 29 ++++--------------- support-services/docker-compose.yml | 22 ++++++++------ .../02-set-default-pipeline.sh | 7 +++++ 4 files changed, 26 insertions(+), 34 deletions(-) create mode 100755 support-services/docker-entrypoint.d/02-set-default-pipeline.sh diff --git a/.github/workflows/checks.yml b/.github/workflows/checks.yml index 08d12bd34e..c4e0dd39e4 100644 --- a/.github/workflows/checks.yml +++ b/.github/workflows/checks.yml @@ -158,7 +158,7 @@ jobs: run: cd tools && docker build . -f pipelines/Dockerfile -t geonetwork/geonetwork-ui-tools-pipelines:latest - name: Build the backend - run: sudo docker-compose -f support-services/docker-compose.yml up -d init tools-pipelines + run: sudo docker-compose -f support-services/docker-compose.yml up -d init - name: Install dependencies run: | diff --git a/apps/datahub-e2e/src/e2e/datasets.cy.ts b/apps/datahub-e2e/src/e2e/datasets.cy.ts index 9152ace7ef..fbc223b296 100644 --- a/apps/datahub-e2e/src/e2e/datasets.cy.ts +++ b/apps/datahub-e2e/src/e2e/datasets.cy.ts @@ -470,43 +470,24 @@ describe('datasets', () => { describe('metadata quality widget enabled', () => { beforeEach(() => { - // this will enable spatial filtering + // this will enable metadata quality widget cy.intercept('GET', '/assets/configuration/default.toml', { fixture: 'config-with-metadata-quality.toml', }) cy.visit('/search') }) - it('should not display widget', () => { - cy.get('@results') - .eq(2) - .get('gn-ui-metadata-quality') - .should('not.exist') - }) - - it('should reindex records', () => { - cy.login('admin', 'admin', false) - cy.visit( - `http://localhost:8080/geonetwork/srv/eng/admin.console#/tools` - ) - cy.intercept({ - method: 'PUT', - url: 'http://localhost:8080/geonetwork/srv/api/site/index?reset=false&asynchronous=true', - }).as('indexingRecordsXHR') - cy.get('[class=panel-body]').find('button').first().click() - cy.wait('@indexingRecordsXHR') - }) it('should display quality widget', () => { - cy.visit('/search') + cy.get('@sortBy').selectDropdownOption('desc,userSavedCount') cy.get('gn-ui-progress-bar') - .eq(2) - .should('have.attr', 'ng-reflect-value', 87) + .eq(0) + .should('have.attr', 'ng-reflect-value', 50) }) it('should display results sorted by quality score', () => { cy.get('@sortBy').selectDropdownOption('desc,qualityScore') cy.get('gn-ui-progress-bar') - .eq(2) + .eq(0) .should('have.attr', 'ng-reflect-value', 100) }) }) diff --git a/support-services/docker-compose.yml b/support-services/docker-compose.yml index 330455c0df..8ee3b01ff6 100644 --- a/support-services/docker-compose.yml +++ b/support-services/docker-compose.yml @@ -99,6 +99,17 @@ services: ports: - '8080:8080' + init-pipeline: + image: geonetwork/geonetwork-ui-tools-pipelines:latest + environment: + ES_HOST: http://elasticsearch:9200 + RECORDS_INDEX: gn-records + depends_on: + geonetwork: + condition: service_healthy + elasticsearch: + condition: service_healthy + init: image: alpine/curl # only run init if volumes were cleared @@ -110,6 +121,8 @@ services: condition: service_healthy elasticsearch: condition: service_healthy + init-pipeline: + condition: service_completed_successfully healthcheck: test: ['CMD-SHELL', "sh -c '[ -f /done ]'"] interval: 5s @@ -140,12 +153,3 @@ services: condition: service_healthy ports: - '8081:8080' - - tools-pipelines: - image: geonetwork/geonetwork-ui-tools-pipelines:latest - environment: - ES_HOST: http://elasticsearch:9200 - RECORDS_INDEX: gn-records - depends_on: - init: - condition: service_completed_successfully diff --git a/support-services/docker-entrypoint.d/02-set-default-pipeline.sh b/support-services/docker-entrypoint.d/02-set-default-pipeline.sh new file mode 100755 index 0000000000..42108454bf --- /dev/null +++ b/support-services/docker-entrypoint.d/02-set-default-pipeline.sh @@ -0,0 +1,7 @@ +#!/bin/sh + +indexConfigDir=/mnt/geonetwork_data/config/index/ + +echo "Setting default pipeline to geonetwork-ui ..." +jq '.settings.index.default_pipeline = "geonetwork-ui"' ${indexConfigDir}records.json > /tmp.json +mv /tmp.json ${indexConfigDir}records.json