Skip to content

Commit

Permalink
jinja refactoring and more test coverage (#629)
Browse files Browse the repository at this point in the history
  • Loading branch information
gdams authored Aug 13, 2024
1 parent 0327d46 commit f56f55b
Show file tree
Hide file tree
Showing 11 changed files with 88 additions and 10 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/code-freeze.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ jobs:

# Code freeze if branch-regex matches
codefreeze_if_branch_match:
permissions:
contents: write
pull-requests: write
needs: codefreeze_branch_check
uses: adoptium/.github/.github/workflows/code-freeze.yml@main
if: (github.event_name == 'pull_request_target' || (github.event_name == 'issue_comment' && github.event.issue.pull_request)) && needs.codefreeze_branch_check.outputs.regex-matches == 'true'
Expand Down
2 changes: 1 addition & 1 deletion docker_templates/alpine-linux.Dockerfile.j2
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ RUN set -eux; \
ca-certificates p11-kit-trust \
# locales ensures proper character encoding and locale-specific behaviors using en_US.UTF-8
musl-locales musl-locales-lang \
{% include 'partials/binutils.j2' -%}
{%- include 'partials/binutils.j2' %}
tzdata \
# Contains `csplit` used for splitting multiple certificates in one file to multiple files, since keytool can
# only import one at a time.
Expand Down
2 changes: 1 addition & 1 deletion docker_templates/nanoserver.Dockerfile.j2
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,4 @@ RUN echo Verifying install ... \
{% endif -%}
&& echo java {% if version|int >= 11 %}--{% else %}-{% endif %}version && java {% if version|int >= 11 %}--{% else %}-{% endif %}version \
&& echo Complete.
{% include 'partials/jshell.j2' %}
{% include 'partials/jshell.j2' %}
2 changes: 1 addition & 1 deletion docker_templates/partials/arch-variable.j2
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,4 @@
ARCH="$(apk --print-arch)"; \
{%- elif os == "ubi9-minimal" %}
ARCH="$(rpm --query --queryformat='%{ARCH}' rpm)"; \
{%- endif -%}
{%- endif -%}
4 changes: 2 additions & 2 deletions docker_templates/partials/binutils.j2
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{% if image_type == "jdk" and version|int >= 13 -%}
{% if image_type == "jdk" and version|int >= 13 %}
# jlink --strip-debug on 13+ needs objcopy: https://github.com/docker-library/openjdk/issues/351
# Error: java.io.IOException: Cannot run program "objcopy": error=2, No such file or directory
binutils \
{% endif -%}
{%- endif -%}
2 changes: 1 addition & 1 deletion docker_templates/partials/multi-arch-install.j2
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,4 @@ RUN set -eux; \
--strip-components 1 \
--no-same-owner \
; \
rm -f /tmp/openjdk.tar.gz ${JAVA_HOME}/lib/src.zip;
rm -f /tmp/openjdk.tar.gz ${JAVA_HOME}/lib/src.zip;
2 changes: 1 addition & 1 deletion docker_templates/partials/version-check-windows.j2
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,4 @@ RUN Write-Host 'Verifying install ...'; \
{% endif -%}
Write-Host 'java {% if version|int >= 11 %}--{% else %}-{% endif %}version'; java {% if version|int >= 11 %}--{% else %}-{% endif %}version; \
\
Write-Host 'Complete.'
Write-Host 'Complete.'
2 changes: 1 addition & 1 deletion docker_templates/partials/version-check.j2
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ RUN set -eux; \
echo "javac {% if version|int >= 11 %}--{% else %}-{% endif %}version"; javac {% if version|int >= 11 %}--{% else %}-{% endif %}version; \
{% endif -%}
echo "java {% if version|int >= 11 %}--{% else %}-{% endif %}version"; java {% if version|int >= 11 %}--{% else %}-{% endif %}version; \
echo "Complete."
echo "Complete."
2 changes: 1 addition & 1 deletion docker_templates/servercore.Dockerfile.j2
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,4 @@ RUN Write-Host ('Downloading {{ arch_data.download_url }} ...'); \
Remove-Item openjdk.msi -Force

{% include 'partials/version-check-windows.j2' %}
{% include 'partials/jshell.j2' %}
{% include 'partials/jshell.j2' %}
2 changes: 1 addition & 1 deletion docker_templates/ubuntu.Dockerfile.j2
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ RUN set -eux; \
# utilities for keeping Ubuntu and OpenJDK CA certificates in sync
# https://github.com/adoptium/containers/issues/293
ca-certificates p11-kit \
{% include 'partials/binutils.j2' -%}
{%- include 'partials/binutils.j2' %}
tzdata \
# locales ensures proper character encoding and locale-specific behaviors using en_US.UTF-8
locales \
Expand Down
75 changes: 75 additions & 0 deletions test_generate_dockerfiles.py
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,81 @@ def test_jdk11plus_jshell_cmd(self):
expected_string = 'CMD ["jshell"]'
self.assertNotIn(expected_string, rendered_template)

def test_binutils_inclusion(self):
template_name = "ubuntu.Dockerfile.j2"
template = self.env.get_template(template_name)

# Binutils should be included for jdk images with version >= 13
with self.subTest("jdk 13+ should include binutils"):
context = {
"version": 13,
"image_type": "jdk",
"os": "ubuntu",
"arch_data": {},
}
rendered_template = template.render(**context)
self.assertIn("binutils", rendered_template)

# Binutils should not be included for jre images regardless of version
with self.subTest("jre 13+ should not include binutils"):
context = {
"version": 13,
"image_type": "jre",
"os": "ubuntu",
"arch_data": {},
}
rendered_template = template.render(**context)
self.assertNotIn("binutils", rendered_template)

# Binutils should not be included for jdk images with version < 13
with self.subTest("jdk < 13 should not include binutils"):
context = {
"version": 12,
"image_type": "jdk",
"os": "ubuntu",
"arch_data": {},
}
rendered_template = template.render(**context)
self.assertNotIn("binutils", rendered_template)

def test_arch_data_population(self):
template_name = "ubuntu.Dockerfile.j2"
template = self.env.get_template(template_name)

# Simulate API response
arch_data = {
"amd64": {
"download_url": "http://fake-url.com",
"checksum": "fake-checksum",
}
}

context = {
"version": 11,
"image_type": "jdk",
"os": "ubuntu",
"arch_data": arch_data,
}
rendered_template = template.render(**context)

self.assertIn("http://fake-url.com", rendered_template)
self.assertIn("fake-checksum", rendered_template)

def test_entrypoint_rendering(self):
template_name = "entrypoint.sh.j2"
template = self.env.get_template(template_name)

context = {
"image_type": "jdk",
"os": "ubuntu",
"version": 11,
}
rendered_template = template.render(**context)

# Ensure that the entrypoint script contains expected commands
self.assertIn("update-ca-certificates", rendered_template)
self.assertIn("exec \"$@\"", rendered_template)


if __name__ == "__main__":
unittest.main()

0 comments on commit f56f55b

Please sign in to comment.