Skip to content

Commit

Permalink
Add support for Debian distros
Browse files Browse the repository at this point in the history
This adds Debian Bullseye and Bookworm support.
The only real change needed here was to update the distro config to
allow us to enable the `bullseye-backports` repo so the tests can
install a more recent version of go (and as such pass the test).

Signed-off-by: Brian Goff <cpuguy83@gmail.com>
  • Loading branch information
cpuguy83 committed Nov 21, 2024
1 parent 0d20ee8 commit 5eee3e7
Show file tree
Hide file tree
Showing 12 changed files with 165 additions and 15 deletions.
2 changes: 2 additions & 0 deletions cmd/frontend/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (

"github.com/Azure/dalec/frontend"
"github.com/Azure/dalec/frontend/azlinux"
"github.com/Azure/dalec/frontend/debian"
"github.com/Azure/dalec/frontend/debug"
"github.com/Azure/dalec/frontend/ubuntu"
"github.com/Azure/dalec/frontend/windows"
Expand Down Expand Up @@ -36,6 +37,7 @@ func main() {
frontend.WithBuiltinHandler(azlinux.AzLinux3TargetKey, azlinux.NewAzlinux3Handler()),
frontend.WithBuiltinHandler(windows.DefaultTargetKey, windows.Handle),
ubuntu.Handlers,
debian.Handlers,
frontend.WithTargetForwardingHandler,
)); err != nil {
bklog.L.WithError(err).Fatal("error running frontend")
Expand Down
5 changes: 4 additions & 1 deletion frontend/deb/distro/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,10 @@ func (c *Config) BuildContainer(worker llb.State, sOpt dalec.SourceOpts, client

opts = append(opts, dalec.ProgressGroup("Build Container Image"))

withRepos, err := c.RepoMounts(spec.GetInstallRepos(targetKey), sOpt, opts...)
repos := dalec.GetExtraRepos(c.ExtraRepos, "install")
repos = append(repos, spec.GetInstallRepos(targetKey)...)

withRepos, err := c.RepoMounts(repos, sOpt, opts...)
if err != nil {
return llb.Scratch(), err
}
Expand Down
5 changes: 5 additions & 0 deletions frontend/deb/distro/distro.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,11 @@ type Config struct {
RepoPlatformConfig *dalec.RepoPlatformConfig

DefaultOutputImage string

// ExtraRepos is used by distributions that want to enable extra repositories
// that are not inthe base worker config.
// A prime example of this is adding Debian backports on debian distrubutions.
ExtraRepos []dalec.PackageRepositoryConfig
}

func (cfg *Config) BuildImageConfig(ctx context.Context, resolver llb.ImageMetaResolver, spec *dalec.Spec, platform *ocispecs.Platform, targetKey string) (*dalec.DockerImageSpec, error) {
Expand Down
11 changes: 9 additions & 2 deletions frontend/deb/distro/install.go
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,10 @@ func (d *Config) InstallBuildDeps(sOpt dalec.SourceOpts, spec *dalec.Spec, targe
return in, errors.Wrap(err, "error creating intermediate package for installing build dependencies")
}

customRepos, err := d.RepoMounts(spec.GetBuildRepos(targetKey), sOpt, opts...)
repos := dalec.GetExtraRepos(d.ExtraRepos, "build")
repos = append(repos, spec.GetBuildRepos(targetKey)...)

customRepos, err := d.RepoMounts(repos, sOpt, opts...)
if err != nil {
return in, err
}
Expand All @@ -153,6 +156,7 @@ func (d *Config) InstallBuildDeps(sOpt dalec.SourceOpts, spec *dalec.Spec, targe
dalec.WithConstraints(opts...),
customRepos,
InstallLocalPkg(pkg, opts...),
dalec.WithMountedAptCache(d.AptCachePrefix),
).Root(), nil
})
}
Expand All @@ -166,7 +170,10 @@ func (d *Config) InstallTestDeps(sOpt dalec.SourceOpts, targetKey string, spec *

return func(in llb.State) llb.State {
return in.Async(func(ctx context.Context, in llb.State, c *llb.Constraints) (llb.State, error) {
withRepos, err := d.RepoMounts(spec.GetTestRepos(targetKey), sOpt, opts...)
repos := dalec.GetExtraRepos(d.ExtraRepos, "test")
repos = append(repos, spec.GetTestRepos(targetKey)...)

withRepos, err := d.RepoMounts(repos, sOpt, opts...)
if err != nil {
return in, err
}
Expand Down
1 change: 1 addition & 0 deletions frontend/deb/distro/worker.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ func (cfg *Config) Worker(sOpt dalec.SourceOpts, opts ...llb.ConstraintsOpt) (ll
Run(
dalec.WithConstraints(opts...),
AptInstall(cfg.BuilderPackages, opts...),
dalec.WithMountedAptCache(cfg.AptCachePrefix),
).
// This file prevents installation of things like docs in ubuntu
// containers We don't want to exclude this because tests want to
Expand Down
25 changes: 25 additions & 0 deletions frontend/debian/bookworm.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
package debian

import (
"github.com/Azure/dalec/frontend/deb/distro"
)

const (
BookwormDefaultTargetKey = "bookworm"
BookwormAptCachePrefix = "bookworm"
BookwormWorkerContextName = "dalec-bookworm-worker"

bookwormRef = "mcr.microsoft.com/mirror/docker/library/debian:bookworm"
bookwormVersionID = "debian12"
)

var (
BookwormConfig = &distro.Config{
ImageRef: bookwormRef,
AptCachePrefix: BookwormAptCachePrefix,
VersionID: bookwormVersionID,
ContextRef: BookwormWorkerContextName,
DefaultOutputImage: bookwormRef,
BuilderPackages: basePackages,
}
)
44 changes: 44 additions & 0 deletions frontend/debian/bullseye.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
package debian

import (
"github.com/Azure/dalec"
"github.com/Azure/dalec/frontend/deb/distro"
)

const (
BullseyeDefaultTargetKey = "bullseye"
BullseyeAptCachePrefix = "bullseye"
BullseyeWorkerContextName = "dalec-bullseye-worker"

bullseyeRef = "mcr.microsoft.com/mirror/docker/library/debian:bullseye"
bullseyeVersionID = "debian11"
)

var (
BullseyeConfig = &distro.Config{
ImageRef: bullseyeRef,
AptCachePrefix: BullseyeAptCachePrefix,
VersionID: bullseyeVersionID,
ContextRef: BullseyeWorkerContextName,
DefaultOutputImage: bullseyeRef,
BuilderPackages: basePackages,

// Ubuntu typically has backports repos already in it but Debian does not.
// Without this the go modules test will fail since there is no viable
// version of go except with the backports repository added.
ExtraRepos: []dalec.PackageRepositoryConfig{
{
Envs: []string{"build", "test", "install"},
Config: map[string]dalec.Source{
"backports.list": {
Inline: &dalec.SourceInline{
File: &dalec.SourceInlineFile{
Contents: "deb http://deb.debian.org/debian bullseye-backports main",
},
},
},
},
},
},
}
)
32 changes: 32 additions & 0 deletions frontend/debian/common.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
package debian

import (
"context"

"github.com/Azure/dalec/frontend"
gwclient "github.com/moby/buildkit/frontend/gateway/client"
)

var (
basePackages = []string{
"aptitude",
"dpkg-dev",
"devscripts",
"equivs",
"fakeroot",
"dh-make",
"build-essential",
"dh-apparmor",
"dh-make",
"dh-exec",
}

targets = map[string]gwclient.BuildFunc{
BookwormDefaultTargetKey: BookwormConfig.Handle,
BullseyeDefaultTargetKey: BullseyeConfig.Handle,
}
)

func Handlers(ctx context.Context, client gwclient.Client, m *frontend.BuildMux) error {
return frontend.LoadBuiltinTargets(targets)(ctx, client, m)
}
14 changes: 14 additions & 0 deletions helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -605,3 +605,17 @@ func BaseImageConfig(platform *ocispecs.Platform) *DockerImageSpec {

return img
}

func (p *PackageDependencies) GetExtraRepos(env string) []PackageRepositoryConfig {
return GetExtraRepos(p.ExtraRepos, env)
}

func GetExtraRepos(repos []PackageRepositoryConfig, env string) []PackageRepositoryConfig {
var out []PackageRepositoryConfig
for _, repo := range repos {
if slices.Contains(repo.Envs, env) {
out = append(repos, repo)
}
}
return out
}
12 changes: 0 additions & 12 deletions spec.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"fmt"
"io/fs"
"regexp"
"slices"
"strings"
"time"

Expand Down Expand Up @@ -359,17 +358,6 @@ type PackageDependencies struct {
ExtraRepos []PackageRepositoryConfig `yaml:"extra_repos,omitempty" json:"extra_repos,omitempty"`
}

func (p *PackageDependencies) GetExtraRepos(env string) []PackageRepositoryConfig {
var repos []PackageRepositoryConfig
for _, repo := range p.ExtraRepos {
if slices.Contains(repo.Envs, env) {
repos = append(repos, repo)
}
}

return repos
}

// PackageRepositoryConfig
type PackageRepositoryConfig struct {
// Keys are the list of keys that need to be imported to use the configured
Expand Down
21 changes: 21 additions & 0 deletions test/debian_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package test

import (
"testing"

"github.com/Azure/dalec/frontend/debian"
)

func TestBookworm(t *testing.T) {
t.Parallel()

ctx := startTestSpan(baseCtx, t)
testLinuxDistro(ctx, t, debLinuxTestConfigFor(debian.BookwormDefaultTargetKey, debian.BookwormConfig))
}

func TestBullseye(t *testing.T) {
t.Parallel()

ctx := startTestSpan(baseCtx, t)
testLinuxDistro(ctx, t, debLinuxTestConfigFor(debian.BullseyeDefaultTargetKey, debian.BullseyeConfig, withPackageOverride("golang", "golang-1.19")))
}
8 changes: 8 additions & 0 deletions website/docs/targets.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,14 @@ bionic/deb (default) Builds a deb package.
bionic/dsc Builds a Debian source package.
bionic/testing/container Builds a container image for testing purposes only.
bionic/worker Builds the worker image.
bookworm/deb (default) Builds a deb package.
bookworm/dsc Builds a Debian source package.
bookworm/testing/container Builds a container image for testing purposes only.
bookworm/worker Builds the worker image.
bullseye/deb (default) Builds a deb package.
bullseye/dsc Builds a Debian source package.
bullseye/testing/container Builds a container image for testing purposes only.
bullseye/worker Builds the worker image.
debug/gomods Outputs all the gomodule dependencies for the spec
debug/resolve Outputs the resolved dalec spec file with build args applied.
debug/sources Outputs all sources from a dalec spec file.
Expand Down

0 comments on commit 5eee3e7

Please sign in to comment.