Code development platform for open source projects from the European Union institutions
Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
N
Netbox Plugins
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
DIGIT-C4
Netbox Plugins
Merge requests
!139
V3 netbox dns extend status choices
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
V3 netbox dns extend status choices
v3_netbox_dns_extend_status_choices
into
develop
Overview
2
Commits
1
Pipelines
11
Changes
2
Merged
Arkadiusz SZCZECINSKI
requested to merge
v3_netbox_dns_extend_status_choices
into
develop
2 months ago
Overview
2
Commits
1
Pipelines
11
Changes
7
Expand
0
0
Merge request reports
Compare
version 2
version 5
2f02adc9
2 months ago
version 4
5157d9d4
2 months ago
version 3
b4422ee5
2 months ago
version 2
a8330f1a
2 months ago
version 1
a8330f1a
2 months ago
develop (base)
and
version 5
latest version
9fe65127
1 commit,
2 months ago
version 5
2f02adc9
1 commit,
2 months ago
version 4
5157d9d4
3 commits,
2 months ago
version 3
b4422ee5
4 commits,
2 months ago
version 2
a8330f1a
3 commits,
2 months ago
version 1
a8330f1a
3 commits,
2 months ago
Show latest version
7 files
+
126
−
108
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
7
Search (e.g. *.vue) (Ctrl+P)
.gitlab/test.yml
0 → 100644
+
105
−
0
Options
workflow
:
rules
:
-
if
:
$CI_PIPELINE_SOURCE == "parent_pipeline"
.test-core
:
&test-core
stage
:
test
tags
:
-
debian12_ovh
variables
:
TEST_TAG
:
test
TEST_HOST
:
localhost
TEST_PORT
:
8000
up-test-env-job
:
<<
:
*test-core
before_script
:
# check that no other unrelated Netbox is up on destination port.
-
if [[ $(curl -f -s http://${TEST_HOST}:${TEST_PORT}/metrics |wc -l) != 0 ]];
then echo "WARNING!! An unrelated Netbox instace has not been shut down properly. Try again, or execute down-test-env-job manually."; exit 1;
fi
# check that runner can do `docker-in-docker`.
-
docker info
# Build image to test
-
docker build --no-cache -t code.europa.eu:4567/digit-c4/netbox-plugins:${TEST_TAG} .
script
:
# Netbox up `http://localhost:8000`
-
env TAG=${TEST_TAG} PORT=${TEST_PORT} docker compose -f docker-compose.yml -f docker-compose.test.yml up -d
# wait for netbox to be up and running
-
for ((i=1; i<20; i++)); do
if [[ $(curl -f -s http://${TEST_HOST}:${TEST_PORT}/metrics |wc -l) < 250 ]];
then echo "not yet up, sleep for 20 seconds.."; sleep 20;
else echo "Netbox up, we are able to reach metrics page. http://${TEST_HOST}:${TEST_PORT}/metrics."; break;
fi;
if [[ $i == 19 ]];
then echo "Netbox seems not able to start on ${TEST_HOST}:${TEST_PORT}."; exit 1;
fi;
done
run-test-job
:
<<
:
*test-core
before_script
:
-
python3 -m venv "$CI_PROJECT_DIR/plugins/venv"
-
source "$CI_PROJECT_DIR/plugins/venv/bin/activate"
-
pip install -r "$CI_PROJECT_DIR/tests/requirements.e2e.txt"
# Remove some tests if plugins are not installed, to keep CI compatibility with different testing branches.
-
for str in {cert,mac,rps}; do
if [[ $(cat requirements.txt | grep -e ${str} | wc -l) == 0 ]]; then
rm -r $CI_PROJECT_DIR/tests/e2e/netbox/netbox_${str}*_plugin;
echo "Removed ${str}'s python tests.";
fi;
done
script
:
-
env HOST="${TEST_HOST}" PORT="${TEST_PORT}" API_KEY="$API_KEY" pytest -s --junit-xml=tests-report-netbox-dist-plugin.xml "$CI_PROJECT_DIR/tests/e2e/"
after_script
:
-
deactivate
-
rm -rf "$CI_PROJECT_DIR/plugins/venv"
artifacts
:
when
:
always
reports
:
junit
:
tests-report-netbox-*-plugin.xml
needs
:
-
up-test-env-job
run-robot-test-job
:
<<
:
*test-core
before_script
:
-
python3 -m venv "$CI_PROJECT_DIR/plugins/venv"
-
source "$CI_PROJECT_DIR/plugins/venv/bin/activate"
-
docker build -t robotframework:latest ./tests/docker/
# Remove some tests if plugins are not installed, to keep CI compatibility with different testing branches.
-
for str in {mac,}; do
if [[ $(cat requirements.txt | grep -e ${str} | wc -l) == 0 ]]; then
rm -r $CI_PROJECT_DIR/tests/robot/netbox_${str}*_plugin;
echo "Removed ${str}'s robot tests.";
fi;
done
script
:
-
docker run --rm -v $CI_PROJECT_DIR:/project --network "host" robotframework:latest bash -c
"robot -v HOST:"${TEST_HOST}" -v PORT:"${TEST_PORT}" -v API_TOKEN:"$API_KEY" --outputdir /project/reports /project/tests/robot/"
after_script
:
-
sudo chmod -R 777 reports
-
docker image rm robotframework:latest --force
-
deactivate
-
rm -rf "$CI_PROJECT_DIR/plugins/venv"
artifacts
:
when
:
always
paths
:
-
reports/*
needs
:
-
up-test-env-job
-
run-test-job
down-test-env-job
:
<<
:
*test-core
script
:
-
echo "Test Env Down"
-
env TAG=${TEST_TAG} PORT=${TEST_PORT} docker compose -f docker-compose.yml -f docker-compose.test.yml down -v
after_script
:
-
docker image rm code.europa.eu:4567/digit-c4/netbox-plugins:${TEST_TAG} --force
-
docker image ls
needs
:
-
up-test-env-job
-
run-test-job
-
run-robot-test-job
when
:
always
Loading