CI: Fix for the runtime docker image build following #8925 (#9044)

Since #8925 `--build-context` flag must be given to build the runtime image. However, it can be used only with BuildKit.
This commit is contained in:
Michał Wawrzyniec Urbańczyk 2024-02-13 19:37:40 +01:00 committed by GitHub
parent 9c982e07b0
commit 64490ec0af
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 36 additions and 16 deletions

View File

@ -23,10 +23,10 @@ pub async fn build_runtime_image(
engine_package_root: generated::EnginePackage,
tag: String,
) -> Result<ImageId> {
ide_ci::fs::copy_to(dockerfile.docker_entrypoint_sh, &engine_package_root.bin)?;
let mut opts = BuildOptions::new(&engine_package_root);
opts.file = Some(dockerfile.dockerfile.to_path_buf());
opts.tags.push(tag);
opts.add_build_context_local("docker-tools", &dockerfile);
let id = Docker.build(opts).await?;
Ok(id)
}

View File

@ -114,6 +114,9 @@ impl Program for Docker {
impl Docker {
pub async fn build(&self, options: BuildOptions) -> Result<ImageId> {
let mut command = self.cmd()?;
if options.buildx {
command.arg("buildx");
}
command.arg("build").args(options.args());
debug!("{:?}", command);
let output = command.output_ok().await?;
@ -279,20 +282,26 @@ impl Docker {
#[derive(Clone, Debug)]
pub struct BuildOptions {
/// Whether the `buildx` (extended build capabilities with BuildKit) should be used.
pub buildx: bool,
pub context: PathBuf,
pub target: Option<OsString>,
pub tags: Vec<String>,
pub build_args: HashMap<String, Option<String>>,
///Named build contexts. Available only for buildx.
pub build_context: HashMap<String, String>,
pub file: Option<PathBuf>,
}
impl BuildOptions {
pub fn new(context_path: impl Into<PathBuf>) -> Self {
Self {
buildx: false,
context: context_path.into(),
target: default(),
tags: default(),
build_args: default(),
build_context: default(),
file: default(),
}
}
@ -342,19 +351,26 @@ impl BuildOptions {
Ok(())
}
pub fn add_build_context_local(&mut self, name: impl Into<String>, path: impl AsRef<Path>) {
self.buildx = true;
self.build_context.insert(name.into(), path.as_ref().as_str().to_string());
}
pub fn args(&self) -> Vec<OsString> {
let Self { buildx: _, context, target, tags, build_args, build_context, file } = self;
let mut ret = Vec::new();
ret.push(self.context.clone().into());
ret.push(context.clone().into());
ret.push("--quiet".into());
if let Some(target) = self.target.as_ref() {
if let Some(target) = target.as_ref() {
ret.push("--target".into());
ret.push(target.clone());
}
for tag in &self.tags {
for tag in tags {
ret.push("--tag".into());
ret.push(tag.into());
}
for (name, value) in &self.build_args {
for (name, value) in build_args {
ret.push("--build-arg".into());
if let Some(value) = value {
ret.push(format!("{name}={value}").into());
@ -362,7 +378,11 @@ impl BuildOptions {
ret.push(name.into());
}
}
if let Some(file) = self.file.as_ref() {
for (name, value) in build_context {
ret.push("--build-context".into());
ret.push(format!("{name}={value}").into());
}
if let Some(file) = file.as_ref() {
ret.push("--file".into());
// Docker can't handle verbatim Dockerfile path. It would fail like:
// `unable to prepare context: unable to get relative Dockerfile path: Rel: can't make