Skip to content

Latest commit

 

History

History
200 lines (160 loc) · 4.84 KB

bazel_kokoro.md

File metadata and controls

200 lines (160 loc) · 4.84 KB

Bazel and Kokoro support for MDC iOS

Bazel is Google's open source build infrastructure. Kokoro is Google's continuous integration infrastructure, presently visible only to Googlers.

Kokoro, like Travis CI, will run continuous integration on the latest commits to develop as well as presubmit checks on pull requests. The entry-point for the kokoro continuous integration script is the .kokoro script in the root of the repo.

Running kokoro presubmits locally

First, ensure that you have installed bazel and at least one version of Xcode.

Run the following command from the root of your MDC-iOS repo to run the presubmits:

./.kokoro

The presubmit script will build and run unit tests against every version of Xcode installed on your local machine. The results of the unit tests will be reported to the console.

Module import statements

When bazel generates modules for use in Swift, module names follow the convention of path_to_component_component. For example, ActivityIndicator would need to be imported like so in a swift file:

import components_ActivityIndicator_ActivityIndicator

However, because we primarily support CocoaPods for public use, we write our import statements like so in the committed code:

import MaterialComponents.MaterialActivityIndicator

The .kokoro script has a pre/post phase where it will translate between the CocoaPods-supported import statements and the bazel-supported import statements.

Note that the kokoro script can only translate import statements that specify the component name. Import statements like the following will need to be updated to use the more specific MaterialComponents.Material<component> pattern:

import MaterialComponents

BUILD files

In order for a component to be included in the kokoro presubmits it must have a BUILD file. This file must be located in the root of the component's folder:

components/
  ActivityIndicator/
    BUILD

Minimal BUILD template

For a component written in Objective-C with only Objective-C tests and no resources or dependencies.

load("//:material_components_ios.bzl",
     "mdc_public_objc_library",
     "mdc_objc_library")
load("@build_bazel_rules_apple//apple:ios.bzl", "ios_unit_test")

licenses(["notice"])  # Apache 2.0

mdc_public_objc_library(
    name = "ComponentName",
    sdk_frameworks = [
        "QuartzCore",
        "UIKit",
    ],
)

mdc_objc_library(
    name = "unit_test_sources",
    testonly = 1,
    srcs = glob(["tests/unit/*.m"]),
    hdrs = glob(["tests/unit/*.h"]),
    sdk_frameworks = [
        "UIKit",
        "XCTest",
    ],
    deps = [":ComponentName"],
    visibility = ["//visibility:private"],
)

ios_unit_test(
    name = "unit_tests",
    deps = [
      ":unit_test_sources",
    ],
    minimum_os_version = "8.0",
    visibility = ["//visibility:private"],
)

Adding dependencies

Dependencies are added as paths relative to the root of the MDC iOS repo:

mdc_public_objc_library(
    name = "ComponentName",
+    deps = ["//components/Palettes"],
)

Adding a Bundle

If your component depends on non-source resources, you can add a bundle target to your component with the following additions:

mdc_public_objc_library(
    name = "ComponentName",
+    bundles = [":Bundle"],
)

+filegroup(
+    name = "BundleFiles",
+    srcs = glob([
+        "src/ComponentName.bundle/**",
+    ]),
+)
+
+objc_bundle(
+    name = "Bundle",
+    bundle_imports = [":BundleFiles"],
+)

Exposing private APIs to unit tests

You can export private APIs such that they are only visible to unit test targets using filegroup rules:

+mdc_objc_library(
+    name = "private",
+    hdrs = native.glob(["src/private/*.h"]),
+    deps = [":Ink"],
+    includes = ["src/private"],
+    visibility = [":test_targets"],
+)
+
+package_group(
+    name = "test_targets",
+    packages = [
+        "//components/ComponentName/...",
+    ],
+)

mdc_objc_library(
    name = "unit_test_sources",
    testonly = 1,
    srcs = glob(["tests/unit/*.m"]),
    hdrs = glob(["tests/unit/*.h"]),
    sdk_frameworks = [
        "UIKit",
        "XCTest",
    ],
    deps = [
        ":ComponentName",
+        ":private"
    ],
    visibility = ["//visibility:private"],
)

Adding Swift unit tests

+load("@build_bazel_rules_apple//apple:swift.bzl", "swift_library")

+swift_library(
+    name = "unit_test_swift_sources",
+    srcs = glob(["tests/unit/*.swift"]),
+    deps = [":ComponentName"],
+    visibility = ["//visibility:private"],
+)

ios_unit_test(
    name = "unit_tests",
    deps = [
      ":unit_test_sources",
+      ":unit_test_swift_sources"
    ],
    minimum_os_version = "8.0",
    visibility = ["//visibility:private"],
)