Skip to content

Commit aa42a7e

Browse files
Merge remote-tracking branch 'upstream/main' into fix-specs-without-expectations_contribute-main
# Conflicts: # src/app/shared/browse-by/shared-browse-by.module.ts
2 parents c4bff4d + 38733e6 commit aa42a7e

447 files changed

Lines changed: 15665 additions & 4993 deletions

File tree

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

.github/disabled-workflows/pull_request_opened.yml

Lines changed: 0 additions & 26 deletions
This file was deleted.

.github/workflows/build.yml

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -43,11 +43,11 @@ jobs:
4343
steps:
4444
# https://github.com/actions/checkout
4545
- name: Checkout codebase
46-
uses: actions/checkout@v3
46+
uses: actions/checkout@v4
4747

4848
# https://github.com/actions/setup-node
4949
- name: Install Node.js ${{ matrix.node-version }}
50-
uses: actions/setup-node@v3
50+
uses: actions/setup-node@v4
5151
with:
5252
node-version: ${{ matrix.node-version }}
5353

@@ -118,7 +118,7 @@ jobs:
118118
# https://github.com/cypress-io/github-action
119119
# (NOTE: to run these e2e tests locally, just use 'ng e2e')
120120
- name: Run e2e tests (integration tests)
121-
uses: cypress-io/github-action@v5
121+
uses: cypress-io/github-action@v6
122122
with:
123123
# Run tests in Chrome, headless mode (default)
124124
browser: chrome
@@ -191,7 +191,7 @@ jobs:
191191
runs-on: ubuntu-latest
192192
steps:
193193
- name: Checkout
194-
uses: actions/checkout@v3
194+
uses: actions/checkout@v4
195195

196196
# Download artifacts from previous 'tests' job
197197
- name: Download coverage artifacts
@@ -203,10 +203,14 @@ jobs:
203203
# Retry action: https://github.com/marketplace/actions/retry-action
204204
# Codecov action: https://github.com/codecov/codecov-action
205205
- name: Upload coverage to Codecov.io
206-
uses: Wandalen/wretry.action@v1.0.36
206+
uses: Wandalen/wretry.action@v1.3.0
207207
with:
208208
action: codecov/codecov-action@v3
209-
# Try upload 5 times max
209+
# Ensure codecov-action throws an error when it fails to upload
210+
# This allows us to auto-restart the action if an error is thrown
211+
with: |
212+
fail_ci_if_error: true
213+
# Try re-running action 5 times max
210214
attempt_limit: 5
211215
# Run again in 30 seconds
212216
attempt_delay: 30000

.github/workflows/codescan.yml

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -5,12 +5,16 @@
55
# because CodeQL requires a fresh build with all tests *disabled*.
66
name: "Code Scanning"
77

8-
# Run this code scan for all pushes / PRs to main branch. Also run once a week.
8+
# Run this code scan for all pushes / PRs to main or maintenance branches. Also run once a week.
99
on:
1010
push:
11-
branches: [ main ]
11+
branches:
12+
- main
13+
- 'dspace-**'
1214
pull_request:
13-
branches: [ main ]
15+
branches:
16+
- main
17+
- 'dspace-**'
1418
# Don't run if PR is only updating static documentation
1519
paths-ignore:
1620
- '**/*.md'
@@ -31,7 +35,7 @@ jobs:
3135
steps:
3236
# https://github.com/actions/checkout
3337
- name: Checkout repository
34-
uses: actions/checkout@v3
38+
uses: actions/checkout@v4
3539

3640
# Initializes the CodeQL tools for scanning.
3741
# https://github.com/github/codeql-action

.github/workflows/docker.yml

Lines changed: 39 additions & 100 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,9 @@ name: Docker images
33

44
# Run this Build for all pushes to 'main' or maintenance branches, or tagged releases.
55
# Also run for PRs to ensure PR doesn't break Docker build process
6+
# NOTE: uses "reusable-docker-build.yml" in DSpace/DSpace to actually build each of the Docker images
7+
# https://github.com/DSpace/DSpace/blob/main/.github/workflows/reusable-docker-build.yml
8+
#
69
on:
710
push:
811
branches:
@@ -16,105 +19,41 @@ permissions:
1619
contents: read # to fetch code (actions/checkout)
1720

1821
jobs:
19-
docker:
22+
#############################################################
23+
# Build/Push the 'dspace/dspace-angular' image
24+
#############################################################
25+
dspace-angular:
2026
# Ensure this job never runs on forked repos. It's only executed for 'dspace/dspace-angular'
2127
if: github.repository == 'dspace/dspace-angular'
22-
runs-on: ubuntu-latest
23-
env:
24-
# Define tags to use for Docker images based on Git tags/branches (for docker/metadata-action)
25-
# For a new commit on default branch (main), use the literal tag 'dspace-7_x' on Docker image.
26-
# For a new commit on other branches, use the branch name as the tag for Docker image.
27-
# For a new tag, copy that tag name as the tag for Docker image.
28-
IMAGE_TAGS: |
29-
type=raw,value=dspace-7_x,enable=${{ endsWith(github.ref, github.event.repository.default_branch) }}
30-
type=ref,event=branch,enable=${{ !endsWith(github.ref, github.event.repository.default_branch) }}
31-
type=ref,event=tag
32-
# Define default tag "flavor" for docker/metadata-action per
33-
# https://github.com/docker/metadata-action#flavor-input
34-
# We turn off 'latest' tag by default.
35-
TAGS_FLAVOR: |
36-
latest=false
37-
# Architectures / Platforms for which we will build Docker images
38-
# If this is a PR, we ONLY build for AMD64. For PRs we only do a sanity check test to ensure Docker builds work.
39-
# If this is NOT a PR (e.g. a tag or merge commit), also build for ARM64.
40-
PLATFORMS: linux/amd64${{ github.event_name != 'pull_request' && ', linux/arm64' || '' }}
41-
42-
steps:
43-
# https://github.com/actions/checkout
44-
- name: Checkout codebase
45-
uses: actions/checkout@v3
46-
47-
# https://github.com/docker/setup-buildx-action
48-
- name: Setup Docker Buildx
49-
uses: docker/setup-buildx-action@v2
50-
51-
# https://github.com/docker/setup-qemu-action
52-
- name: Set up QEMU emulation to build for multiple architectures
53-
uses: docker/setup-qemu-action@v2
54-
55-
# https://github.com/docker/login-action
56-
- name: Login to DockerHub
57-
# Only login if not a PR, as PRs only trigger a Docker build and not a push
58-
if: github.event_name != 'pull_request'
59-
uses: docker/login-action@v2
60-
with:
61-
username: ${{ secrets.DOCKER_USERNAME }}
62-
password: ${{ secrets.DOCKER_ACCESS_TOKEN }}
63-
64-
###############################################
65-
# Build/Push the 'dspace/dspace-angular' image
66-
###############################################
67-
# https://github.com/docker/metadata-action
68-
# Get Metadata for docker_build step below
69-
- name: Sync metadata (tags, labels) from GitHub to Docker for 'dspace-angular' image
70-
id: meta_build
71-
uses: docker/metadata-action@v4
72-
with:
73-
images: dspace/dspace-angular
74-
tags: ${{ env.IMAGE_TAGS }}
75-
flavor: ${{ env.TAGS_FLAVOR }}
76-
77-
# https://github.com/docker/build-push-action
78-
- name: Build and push 'dspace-angular' image
79-
id: docker_build
80-
uses: docker/build-push-action@v3
81-
with:
82-
context: .
83-
file: ./Dockerfile
84-
platforms: ${{ env.PLATFORMS }}
85-
# For pull requests, we run the Docker build (to ensure no PR changes break the build),
86-
# but we ONLY do an image push to DockerHub if it's NOT a PR
87-
push: ${{ github.event_name != 'pull_request' }}
88-
# Use tags / labels provided by 'docker/metadata-action' above
89-
tags: ${{ steps.meta_build.outputs.tags }}
90-
labels: ${{ steps.meta_build.outputs.labels }}
91-
92-
#####################################################
93-
# Build/Push the 'dspace/dspace-angular' image ('-dist' tag)
94-
#####################################################
95-
# https://github.com/docker/metadata-action
96-
# Get Metadata for docker_build_dist step below
97-
- name: Sync metadata (tags, labels) from GitHub to Docker for 'dspace-angular-dist' image
98-
id: meta_build_dist
99-
uses: docker/metadata-action@v4
100-
with:
101-
images: dspace/dspace-angular
102-
tags: ${{ env.IMAGE_TAGS }}
103-
# As this is a "dist" image, its tags are all suffixed with "-dist". Otherwise, it uses the same
104-
# tagging logic as the primary 'dspace/dspace-angular' image above.
105-
flavor: ${{ env.TAGS_FLAVOR }}
106-
suffix=-dist
107-
108-
- name: Build and push 'dspace-angular-dist' image
109-
id: docker_build_dist
110-
uses: docker/build-push-action@v3
111-
with:
112-
context: .
113-
file: ./Dockerfile.dist
114-
platforms: ${{ env.PLATFORMS }}
115-
# For pull requests, we run the Docker build (to ensure no PR changes break the build),
116-
# but we ONLY do an image push to DockerHub if it's NOT a PR
117-
push: ${{ github.event_name != 'pull_request' }}
118-
# Use tags / labels provided by 'docker/metadata-action' above
119-
tags: ${{ steps.meta_build_dist.outputs.tags }}
120-
labels: ${{ steps.meta_build_dist.outputs.labels }}
28+
# Use the reusable-docker-build.yml script from DSpace/DSpace repo to build our Docker image
29+
uses: DSpace/DSpace/.github/workflows/reusable-docker-build.yml@main
30+
with:
31+
build_id: dspace-angular
32+
image_name: dspace/dspace-angular
33+
dockerfile_path: ./Dockerfile
34+
secrets:
35+
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
36+
DOCKER_ACCESS_TOKEN: ${{ secrets.DOCKER_ACCESS_TOKEN }}
37+
38+
#############################################################
39+
# Build/Push the 'dspace/dspace-angular' image ('-dist' tag)
40+
#############################################################
41+
dspace-angular-dist:
42+
# Ensure this job never runs on forked repos. It's only executed for 'dspace/dspace-angular'
43+
if: github.repository == 'dspace/dspace-angular'
44+
# Use the reusable-docker-build.yml script from DSpace/DSpace repo to build our Docker image
45+
uses: DSpace/DSpace/.github/workflows/reusable-docker-build.yml@main
46+
with:
47+
build_id: dspace-angular-dist
48+
image_name: dspace/dspace-angular
49+
dockerfile_path: ./Dockerfile.dist
50+
# As this is a "dist" image, its tags are all suffixed with "-dist". Otherwise, it uses the same
51+
# tagging logic as the primary 'dspace/dspace-angular' image above.
52+
tags_flavor: suffix=-dist
53+
secrets:
54+
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
55+
DOCKER_ACCESS_TOKEN: ${{ secrets.DOCKER_ACCESS_TOKEN }}
56+
# Enable redeploy of sandbox & demo if the branch for this image matches the deployment branch of
57+
# these sites as specified in reusable-docker-build.xml
58+
REDEPLOY_SANDBOX_URL: ${{ secrets.REDEPLOY_SANDBOX_URL }}
59+
REDEPLOY_DEMO_URL: ${{ secrets.REDEPLOY_DEMO_URL }}

.github/workflows/label_merge_conflicts.yml

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,12 @@
11
# This workflow checks open PRs for merge conflicts and labels them when conflicts are found
22
name: Check for merge conflicts
33

4-
# Run whenever the "main" branch is updated
5-
# NOTE: This means merge conflicts are only checked for when a PR is merged to main.
4+
# Run this for all pushes (i.e. merges) to 'main' or maintenance branches
65
on:
76
push:
8-
branches: [ main ]
7+
branches:
8+
- main
9+
- 'dspace-**'
910
# So that the `conflict_label_name` is removed if conflicts are resolved,
1011
# we allow this to run for `pull_request_target` so that github secrets are available.
1112
pull_request_target:
@@ -24,6 +25,8 @@ jobs:
2425
# See: https://github.com/prince-chrismc/label-merge-conflicts-action
2526
- name: Auto-label PRs with merge conflicts
2627
uses: prince-chrismc/label-merge-conflicts-action@v3
28+
# Ignore any failures -- may occur (randomly?) for older, outdated PRs.
29+
continue-on-error: true
2730
# Add "merge conflict" label if a merge conflict is detected. Remove it when resolved.
2831
# Note, the authentication token is created automatically
2932
# See: https://docs.github.com/en/actions/configuring-and-managing-workflows/authenticating-with-the-github_token
Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
# This workflow will attempt to port a merged pull request to
2+
# the branch specified in a "port to" label (if exists)
3+
name: Port merged Pull Request
4+
5+
# Only run for merged PRs against the "main" or maintenance branches
6+
# We allow this to run for `pull_request_target` so that github secrets are available
7+
# (This is required when the PR comes from a forked repo)
8+
on:
9+
pull_request_target:
10+
types: [ closed ]
11+
branches:
12+
- main
13+
- 'dspace-**'
14+
15+
permissions:
16+
contents: write # so action can add comments
17+
pull-requests: write # so action can create pull requests
18+
19+
jobs:
20+
port_pr:
21+
runs-on: ubuntu-latest
22+
# Don't run on closed *unmerged* pull requests
23+
if: github.event.pull_request.merged
24+
steps:
25+
# Checkout code
26+
- uses: actions/checkout@v4
27+
# Port PR to other branch (ONLY if labeled with "port to")
28+
# See https://github.com/korthout/backport-action
29+
- name: Create backport pull requests
30+
uses: korthout/backport-action@v2
31+
with:
32+
# Trigger based on a "port to [branch]" label on PR
33+
# (This label must specify the branch name to port to)
34+
label_pattern: '^port to ([^ ]+)$'
35+
# Title to add to the (newly created) port PR
36+
pull_title: '[Port ${target_branch}] ${pull_title}'
37+
# Description to add to the (newly created) port PR
38+
pull_description: 'Port of #${pull_number} by @${pull_author} to `${target_branch}`.'
39+
# Copy all labels from original PR to (newly created) port PR
40+
# NOTE: The labels matching 'label_pattern' are automatically excluded
41+
copy_labels_pattern: '.*'
42+
# Skip any merge commits in the ported PR. This means only non-merge commits are cherry-picked to the new PR
43+
merge_commits: 'skip'
44+
# Use a personal access token (PAT) to create PR as 'dspace-bot' user.
45+
# A PAT is required in order for the new PR to trigger its own actions (for CI checks)
46+
github_token: ${{ secrets.PR_PORT_TOKEN }}
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# This workflow runs whenever a new pull request is created
2+
name: Pull Request opened
3+
4+
# Only run for newly opened PRs against the "main" or maintenance branches
5+
# We allow this to run for `pull_request_target` so that github secrets are available
6+
# (This is required to assign a PR back to the creator when the PR comes from a forked repo)
7+
on:
8+
pull_request_target:
9+
types: [ opened ]
10+
branches:
11+
- main
12+
- 'dspace-**'
13+
14+
permissions:
15+
pull-requests: write
16+
17+
jobs:
18+
automation:
19+
runs-on: ubuntu-latest
20+
steps:
21+
# Assign the PR to whomever created it. This is useful for visualizing assignments on project boards
22+
# See https://github.com/toshimaru/auto-author-assign
23+
- name: Assign PR to creator
24+
uses: toshimaru/auto-author-assign@v2.0.1

Dockerfile.dist

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
# See https://github.com/DSpace/dspace-angular/tree/main/docker for usage details
33

44
# Test build:
5-
# docker build -f Dockerfile.dist -t dspace/dspace-angular:dspace-7_x-dist .
5+
# docker build -f Dockerfile.dist -t dspace/dspace-angular:latest-dist .
66

77
FROM node:18-alpine as build
88

README.md

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -157,8 +157,8 @@ DSPACE_UI_SSL => DSPACE_SSL
157157

158158
The same settings can also be overwritten by setting system environment variables instead, E.g.:
159159
```bash
160-
export DSPACE_HOST=api7.dspace.org
161-
export DSPACE_UI_PORT=4200
160+
export DSPACE_HOST=demo.dspace.org
161+
export DSPACE_UI_PORT=4000
162162
```
163163

164164
The priority works as follows: **environment variable** overrides **variable in `.env` file** overrides external config set by `DSPACE_APP_CONFIG_PATH` overrides **`config.(prod or dev).yml`**
@@ -288,7 +288,7 @@ E2E tests (aka integration tests) use [Cypress.io](https://www.cypress.io/). Con
288288
The test files can be found in the `./cypress/integration/` folder.
289289

290290
Before you can run e2e tests, two things are REQUIRED:
291-
1. You MUST be running the DSpace backend (i.e. REST API) locally. The e2e tests will *NOT* succeed if run against our demo REST API (https://api7.dspace.org/server/), as that server is uncontrolled and may have content added/removed at any time.
291+
1. You MUST be running the DSpace backend (i.e. REST API) locally. The e2e tests will *NOT* succeed if run against our demo/sandbox REST API (https://demo.dspace.org/server/ or https://sandbox.dspace.org/server/), as those sites may have content added/removed at any time.
292292
* After starting up your backend on localhost, make sure either your `config.prod.yml` or `config.dev.yml` has its `rest` settings defined to use that localhost backend.
293293
* If you'd prefer, you may instead use environment variables as described at [Configuring](#configuring). For example:
294294
```

0 commit comments

Comments
 (0)