From d3b5de889b9f22b40122d5ebb2bf144057cc4597 Mon Sep 17 00:00:00 2001 From: Fabian Meumertzheim Date: Sun, 16 Jan 2022 14:52:37 +0100 Subject: [PATCH] Add basic bzlmod setup This commit adds a MODULE.bazel that makes rules_go usable as a bzlmod module for basic use cases. The new module definition is verified by a test module that will be used in the presubmit tests of the Bazel Central Registry (BCR). The following features require more thought and/or work and are not yet supported: * SDK rules other than go_host_sdk and go_download_sdk. * non-no-op nogo * go_proto_library --- .bazelci/presubmit.yml | 14 +++++++++++ .bazelignore | 1 + .gitignore | 1 + MODULE.bazel | 21 ++++++++++++++++ bcr_tests/.bazelrc | 1 + bcr_tests/.bazelversion | 1 + bcr_tests/BUILD.bazel | 19 ++++++++++++++ bcr_tests/MODULE.bazel | 16 ++++++++++++ bcr_tests/WORKSPACE | 0 bcr_tests/lib.go | 5 ++++ bcr_tests/main.go | 11 ++++++++ bcr_tests/test.go | 11 ++++++++ go/extensions.bzl | 3 +++ go/private/extensions.bzl | 53 +++++++++++++++++++++++++++++++++++++++ 14 files changed, 157 insertions(+) create mode 100644 .bazelignore create mode 100644 MODULE.bazel create mode 100644 bcr_tests/.bazelrc create mode 100644 bcr_tests/.bazelversion create mode 100644 bcr_tests/BUILD.bazel create mode 100644 bcr_tests/MODULE.bazel create mode 100644 bcr_tests/WORKSPACE create mode 100644 bcr_tests/lib.go create mode 100644 bcr_tests/main.go create mode 100644 bcr_tests/test.go create mode 100644 go/extensions.bzl create mode 100644 go/private/extensions.bzl diff --git a/.bazelci/presubmit.yml b/.bazelci/presubmit.yml index 6079c6526d..6ef77a0ee0 100644 --- a/.bazelci/presubmit.yml +++ b/.bazelci/presubmit.yml @@ -23,6 +23,20 @@ tasks: - "//..." test_targets: - "//..." + ubuntu2004_bcr_tests: + platform: ubuntu2004 + # Until 5.0.0 has been released, use a Bazel version that contains + # https://github.com/bazelbuild/bazel/commit/48a0fc51ccf6a3a263b9f8d96921d84d4243e0e6 + bazel: 20d880770fb5657d4cb35c971d074b6965a820a8 + working_directory: bcr_tests + build_flags: + - "--experimental_enable_bzlmod" + test_flags: + - "--experimental_enable_bzlmod" + build_targets: + - "//..." + test_targets: + - "//..." macos: shell_commands: - tests/core/cgo/generate_imported_dylib.sh diff --git a/.bazelignore b/.bazelignore new file mode 100644 index 0000000000..6fb14b34fe --- /dev/null +++ b/.bazelignore @@ -0,0 +1 @@ +bcr_tests diff --git a/.gitignore b/.gitignore index 0f1e744f59..8611787e37 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ /bazel-* /tests/core/cgo/libimported.* /tests/core/cgo/libversioned.* +/bcr_tests/bazel-* diff --git a/MODULE.bazel b/MODULE.bazel new file mode 100644 index 0000000000..108bfb0c7b --- /dev/null +++ b/MODULE.bazel @@ -0,0 +1,21 @@ +module( + name = "io_bazel_rules_go", + version = "0.29.0", + compatibility_level = 1, + toolchains_to_register = [ + "@go_host_sdk//:all", + ], +) + +bazel_dep(name = "bazel_skylib", version = "1.1.1") +bazel_dep(name = "platforms", version = "0.0.4") + +non_module_dependencies = use_extension("@io_bazel_rules_go//go/private:extensions.bzl", "non_module_dependencies") +use_repo( + non_module_dependencies, + "io_bazel_rules_nogo", +) + +go_sdk = use_extension("@io_bazel_rules_go//go:extensions.bzl", "go_sdk") +go_sdk.host(name = "go_host_sdk") +use_repo(go_sdk, "go_host_sdk") diff --git a/bcr_tests/.bazelrc b/bcr_tests/.bazelrc new file mode 100644 index 0000000000..e2ece0c386 --- /dev/null +++ b/bcr_tests/.bazelrc @@ -0,0 +1 @@ +build --experimental_enable_bzlmod diff --git a/bcr_tests/.bazelversion b/bcr_tests/.bazelversion new file mode 100644 index 0000000000..c2c41e1830 --- /dev/null +++ b/bcr_tests/.bazelversion @@ -0,0 +1 @@ +20d880770fb5657d4cb35c971d074b6965a820a8 diff --git a/bcr_tests/BUILD.bazel b/bcr_tests/BUILD.bazel new file mode 100644 index 0000000000..834771ef91 --- /dev/null +++ b/bcr_tests/BUILD.bazel @@ -0,0 +1,19 @@ +load("@rules_go//go:def.bzl", "go_binary", "go_library", "go_test") + +go_library( + name = "lib", + srcs = ["lib.go"], + importpath = "example.com/lib", +) + +go_binary( + name = "main", + srcs = ["main.go"], + deps = [":lib"], +) + +go_test( + name = "test", + srcs = ["test.go"], + embed = [":lib"], +) diff --git a/bcr_tests/MODULE.bazel b/bcr_tests/MODULE.bazel new file mode 100644 index 0000000000..6456198810 --- /dev/null +++ b/bcr_tests/MODULE.bazel @@ -0,0 +1,16 @@ +module( + name = "rules_go_bcr_tests", + toolchains_to_register = [ + "@go_sdk//:all", + ], +) + +bazel_dep(name = "io_bazel_rules_go", version = "", repo_name = "rules_go") +local_path_override( + module_name = "io_bazel_rules_go", + path = "..", +) + +go_sdk = use_extension("@rules_go//go:extensions.bzl", "go_sdk") +go_sdk.download(name = "go_sdk", version = "1.17.5") +use_repo(go_sdk, "go_sdk") diff --git a/bcr_tests/WORKSPACE b/bcr_tests/WORKSPACE new file mode 100644 index 0000000000..e69de29bb2 diff --git a/bcr_tests/lib.go b/bcr_tests/lib.go new file mode 100644 index 0000000000..d162287c3d --- /dev/null +++ b/bcr_tests/lib.go @@ -0,0 +1,5 @@ +package lib + +func Name() string { + return "bzlmod" +} diff --git a/bcr_tests/main.go b/bcr_tests/main.go new file mode 100644 index 0000000000..46c058ef1d --- /dev/null +++ b/bcr_tests/main.go @@ -0,0 +1,11 @@ +package main + +import ( + "fmt" + + "example.com/lib" +) + +func main() { + fmt.Printf("Hello %s!", lib.Name()) +} diff --git a/bcr_tests/test.go b/bcr_tests/test.go new file mode 100644 index 0000000000..910c06beec --- /dev/null +++ b/bcr_tests/test.go @@ -0,0 +1,11 @@ +package lib + +import ( + "testing" +) + +func TestName(t *testing.T) { + if Name() != "bzlmod" { + t.Fail() + } +} diff --git a/go/extensions.bzl b/go/extensions.bzl new file mode 100644 index 0000000000..f7c86ada2a --- /dev/null +++ b/go/extensions.bzl @@ -0,0 +1,3 @@ +load("//go/private:extensions.bzl", _go_sdk = "go_sdk") + +go_sdk = _go_sdk diff --git a/go/private/extensions.bzl b/go/private/extensions.bzl new file mode 100644 index 0000000000..cb88521cf7 --- /dev/null +++ b/go/private/extensions.bzl @@ -0,0 +1,53 @@ +load("//go/private:sdk.bzl", "go_download_sdk", "go_host_sdk") +load("//go/private:repositories.bzl", "go_rules_dependencies") + +_download_tag = tag_class( + attrs = { + "name": attr.string(mandatory = True), + "goos": attr.string(), + "goarch": attr.string(), + "sdks": attr.string_list_dict(), + "urls": attr.string_list(default = ["https://dl.google.com/go/{}"]), + "version": attr.string(), + "strip_prefix": attr.string(default = "go"), + }, +) + +_host_tag = tag_class( + attrs = { + "name": attr.string(mandatory = True), + }, +) + +def _go_sdk_impl(ctx): + for mod in ctx.modules: + for download_tag in mod.tags.download: + go_download_sdk( + name = download_tag.name, + goos = download_tag.goos, + goarch = download_tag.goarch, + sdks = download_tag.sdks, + urls = download_tag.urls, + version = download_tag.version, + register_toolchains = False, + ) + for host_tag in mod.tags.host: + go_host_sdk( + name = host_tag.name, + register_toolchains = False, + ) + +go_sdk = module_extension( + implementation = _go_sdk_impl, + tag_classes = { + "download": _download_tag, + "host": _host_tag, + }, +) + +def _non_module_dependencies_impl(ctx): + go_rules_dependencies(force = True) + +non_module_dependencies = module_extension( + implementation = _non_module_dependencies_impl, +)