Ver código fonte

Merge pull request #74 from mapx/update_bazel_build

Update bazel build module
Jupp Müller 8 anos atrás
pai
commit
57f4ce18be
9 arquivos alterados com 204 adições e 291 exclusões
  1. 30 29
      BUILD
  2. 32 76
      README.md
  3. 3 114
      WORKSPACE
  4. 0 66
      WORKSPACE.example
  5. 133 0
      repositories.bzl
  6. 2 2
      tests/BUILD
  7. 2 2
      tests/benchmark/BUILD
  8. 1 1
      tests/integration/BUILD
  9. 1 1
      tests/integration/sample_server.cc

+ 30 - 29
BUILD

@@ -1,33 +1,34 @@
 cc_library(
-    name = "prometheus-cpp",
-    srcs = ["lib/check_names.cc",
-            "lib/counter.cc",
-            "lib/gauge.cc",
-            "lib/exposer.cc",
-            "lib/handler.cc",
-            "lib/handler.h",
-            "lib/histogram.cc",
-            "lib/registry.cc",
-            "lib/text_serializer.cc",
-            "lib/text_serializer.h",
-            "lib/json_serializer.cc",
-            "lib/json_serializer.h",
-            "lib/serializer.h",
-            "lib/protobuf_delimited_serializer.cc",
-            "lib/protobuf_delimited_serializer.h",
-            "lib/counter_builder.cc",
-            "lib/gauge_builder.cc",
-            "lib/histogram_builder.cc",
-],
-    hdrs = glob([
-        "include/prometheus/*.h",
-    ]),
+    name = "prometheus_cpp",
+    srcs = [
+        "lib/check_names.cc",
+        "lib/counter.cc",
+        "lib/counter_builder.cc",
+        "lib/exposer.cc",
+        "lib/gauge.cc",
+        "lib/gauge_builder.cc",
+        "lib/handler.cc",
+        "lib/handler.h",
+        "lib/histogram.cc",
+        "lib/histogram_builder.cc",
+        "lib/json_serializer.cc",
+        "lib/json_serializer.h",
+        "lib/protobuf_delimited_serializer.cc",
+        "lib/protobuf_delimited_serializer.h",
+        "lib/registry.cc",
+        "lib/serializer.h",
+        "lib/text_serializer.cc",
+        "lib/text_serializer.h",
+    ],
+    hdrs = glob(
+        ["include/prometheus/*.h"],
+    ),
+    linkstatic = 1,
     strip_include_prefix = "include",
     visibility = ["//visibility:public"],
-    deps = ["@protobuf//:protobuf",
-            "@prometheus_client_model//:prometheus_client_model",
-            "@civetweb//:civetweb",
-           ],
-    linkstatic = 1,
-    copts = ["-I."],
+    deps = [
+        "@civetweb//:civetweb",
+        "@com_google_protobuf//:protobuf",
+        "@prometheus_client_model//:prometheus_client_model",
+    ],
 )

+ 32 - 76
README.md

@@ -17,14 +17,14 @@ other push/pull collections can be added as plugins.
 #include <string>
 #include <thread>
 
-#include "lib/exposer.h"
-#include "lib/registry.h"
+#include <prometheus/exposer.h>
+#include <prometheus/registry.h>
 
 int main(int argc, char** argv) {
   using namespace prometheus;
 
   // create an http server running on port 8080
-  auto exposer = Exposer{"127.0.0.1:8080"};
+  Exposer exposer{"127.0.0.1:8080"};
 
   // create a metrics registry with component=main labels applied to all its
   // metrics
@@ -97,107 +97,63 @@ make DESTDIR=`pwd`/deploy install
 ### via Bazel
 
 Install [bazel](https://www.bazel.io).  Bazel makes it easy to add
-this repo to your project as a dependency. Unfortunately some of the
-direct and transitive dependencies do not provide bazel files. You need
-to add the following to your WORKSPACE:
-
-```
-new_git_repository(
-    name = "prometheus_client_model",
-    remote = "https://github.com/prometheus/client_model.git",
-    commit = "e2da43a",
-    build_file_content = """
-cc_library(
-    name = "prometheus_client_model",
-    srcs = [
-        "cpp/metrics.pb.cc",
-    ],
-    hdrs = [
-         "cpp/metrics.pb.h",
-    ],
-    includes = [
-         "cpp",
-    ],
-    visibility = ["//visibility:public"],
-    deps = ["@protobuf//:protobuf"],
-)
-    """,
-)
+this repo to your project as a dependency. Just add the following
+to your `WORKSPACE`:
 
+```python
 git_repository(
-    name = "protobuf",
-    remote = "https://github.com/google/protobuf.git",
-    tag = "v3.0.0",
-    )
-
-new_git_repository(
-    name = "civetweb",
-    remote = "https://github.com/civetweb/civetweb.git",
-    commit = "fbdee74",
-    build_file_content = """
-cc_library(
-    name = "civetweb",
-    srcs = [
-         "src/civetweb.c",
-         "src/CivetServer.cpp",
-    ],
-    hdrs = [
-         "include/civetweb.h",
-         "include/CivetServer.h",
-         "src/md5.inl",
-         "src/handle_form.inl",
-    ],
-    includes = [
-         "include",
-    ],
-    copts = [
-          "-DUSE_IPV6",
-          "-DNDEBUG",
-          "-DNO_CGI",
-          "-DNO_CACHING",
-          "-DNO_SSL",
-          "-DNO_FILES",
-    ],
-    visibility = ["//visibility:public"],
-)
-"""
+    name = "prometheus_cpp",
+    remote = https://github.com/jupp0r/prometheus-cpp.git",
 )
 
-git_repository(
-    name = "prometheus_cpp",
-    remote = "https://github.com/jupp0r/prometheus-cpp.git",
-    commit = "9c865b1c1a4234fa063e91225bb228111ee922ac",
-    )
+load("@prometheus_cpp//:repositories.bzl", "prometheus_cpp_repositories")
+
+prometheus_cpp_repositories()
 ```
 
-Then, you can reference this library in your own BUILD file, as
+Then, you can reference this library in your own `BUILD` file, as
 demonstrated with the sample server included in this repository:
 
-```
+```python
 cc_binary(
     name = "sample_server",
     srcs = ["sample_server.cc"],
-    deps = ["@prometheus_cpp//lib:prometheus-cpp"],
+    deps = ["@prometheus_cpp//:prometheus_cpp"],
 )
 ```
 
+When you call `prometheus_cpp_repositories()` in your `WORKSPACE` file,
+you introduce the following dependencies to your project:
+
+* `load_com_google_protobuf()` for Google protobuf
+* `load_prometheus_client_model()` for Prometheus data model artifacts
+* `load_civetweb()` for Civetweb
+* `load_com_google_googletest()` for Google gtest
+* `load_com_google_googlebenchmark()` for Googlebenchmark
+
+You may load them individually and replace some of them with your custom
+dependency version.
+
+The list of dependencies is also available from file `repositories.bzl`.
+
+
 ## Contributing
 
 You can check out this repo and build the library using
 ``` bash
-bazel build //:prometheus-cpp
+bazel build //:prometheus_cpp
 ```
 
 Run the unit tests using
 ```
-bazel test //tests:prometheus_test
+bazel test //tests:prometheus-test
 ```
 
 There is also an integration test that
 uses [telegraf](https://github.com/influxdata/telegraf) to scrape a
 sample server. With telegraf installed, it can be run using
 ```
-bazel test //tests/integration:scrape_test
+bazel test //tests/integration:scrape-test
 ```
 
 ## Benchmarks

+ 3 - 114
WORKSPACE

@@ -1,116 +1,5 @@
-new_git_repository(
-    name = "googletest",
-    remote = "https://github.com/google/googletest.git",
-    tag = "release-1.8.0",
-    build_file_content = """
-cc_library(
-    name = "gmock",
-    srcs = [
-        "googletest/src/gtest-all.cc",
-        "googlemock/src/gmock-all.cc",
-    ],
-    hdrs = glob([
-        "googletest/**/*.h",
-        "googlemock/**/*.h",
-        "googletest/src/*.cc",
-        "googlemock/src/*.cc",
-    ]),
-    includes = [
-        "googlemock",
-        "googletest",
-        "googletest/include",
-        "googlemock/include",
-    ],
-    linkopts = ["-pthread"],
-    visibility = ["//visibility:public"],
-)
+workspace(name = "prometheus_cpp")
 
-cc_library(
-    name = "main",
-    srcs = ["googlemock/src/gmock_main.cc"],
-    linkopts = ["-pthread"],
-    visibility = ["//visibility:public"],
-    deps = [":gmock"],
-)
+load(":repositories.bzl", "prometheus_cpp_repositories")
 
-""",
-)
-
-new_git_repository(
-    name = "prometheus_client_model",
-    remote = "https://github.com/prometheus/client_model.git",
-    commit = "e2da43a",
-    build_file_content = """
-load("@protobuf//:protobuf.bzl", "cc_proto_library")
-cc_proto_library(
-    name = "prometheus_client_model",
-    srcs = ["metrics.proto"],
-    protoc = "@protobuf//:protoc",
-    default_runtime = "@protobuf//:protobuf",
-    visibility = ["//visibility:public"],
-)
-    """,
-)
-
-git_repository(
-    name = "protobuf",
-    remote = "https://github.com/google/protobuf.git",
-    tag = "v3.2.0",
-    )
-
-new_git_repository(
-    name = "civetweb",
-    remote = "https://github.com/civetweb/civetweb.git",
-    commit = "fbdee74",
-    build_file_content = """
-cc_library(
-    name = "civetweb",
-    srcs = [
-         "src/civetweb.c",
-         "src/CivetServer.cpp",
-    ],
-    hdrs = [
-         "include/civetweb.h",
-         "include/CivetServer.h",
-    ],
-    textual_hdrs = [
-         "src/md5.inl",
-         "src/handle_form.inl",
-    ],
-    includes = [
-         "include",
-    ],
-    copts = [
-          "-DUSE_IPV6",
-          "-DNDEBUG",
-          "-DNO_CGI",
-          "-DNO_CACHING",
-          "-DNO_SSL",
-          "-DNO_FILES",
-    ],
-    visibility = ["//visibility:public"],
-)
-"""
-)
-
-new_git_repository(
-    name = "googlebenchmark",
-    remote = "https://github.com/google/benchmark.git",
-    commit = "57a22c69b382b3f010ec4042c9574ea3fd8dcbb4",
-    build_file_content = """
-cc_library(
-    name = "googlebenchmark",
-    srcs = glob(["src/*.cc"],
-                exclude = ["src/re_posix.cc", "src/gnuregex.cc"]),
-    hdrs = glob(["src/*.h", "include/benchmark/*.h"],
-                exclude = ["src/re_posix.h", "src/gnuregex.h"]),
-    includes = [
-         "include",
-    ],
-    visibility = ["//visibility:public"],
-    copts = [
-          "-DHAVE_STD_REGEX"
-    ],
-)
-"""
-)
+prometheus_cpp_repositories()

+ 0 - 66
WORKSPACE.example

@@ -1,66 +0,0 @@
-new_git_repository(
-    name = "prometheus_client_model",
-    remote = "https://github.com/prometheus/client_model.git",
-    commit = "e2da43a",
-    build_file_content = """
-cc_library(
-    name = "prometheus_client_model",
-    srcs = [
-        "cpp/metrics.pb.cc",
-    ],
-    hdrs = [
-         "cpp/metrics.pb.h",
-    ],
-    includes = [
-         "cpp",
-    ],
-    visibility = ["//visibility:public"],
-    deps = ["@protobuf//:protobuf"],
-)
-    """,
-)
-
-git_repository(
-    name = "protobuf",
-    remote = "https://github.com/google/protobuf.git",
-    tag = "v3.0.0",
-    )
-
-new_git_repository(
-    name = "civetweb",
-    remote = "https://github.com/civetweb/civetweb.git",
-    commit = "fbdee74",
-    build_file_content = """
-cc_library(
-    name = "civetweb",
-    srcs = [
-         "src/civetweb.c",
-         "src/CivetServer.cpp",
-    ],
-    hdrs = [
-         "include/civetweb.h",
-         "include/CivetServer.h",
-         "src/md5.inl",
-         "src/handle_form.inl",
-    ],
-    includes = [
-         "include",
-    ],
-    copts = [
-          "-DUSE_IPV6",
-          "-DNDEBUG",
-          "-DNO_CGI",
-          "-DNO_CACHING",
-          "-DNO_SSL",
-          "-DNO_FILES",
-    ],
-    visibility = ["//visibility:public"],
-)
-"""
-)
-
-git_repository(
-    name = "prometheus_cpp",
-    remote = "https://github.com/jupp0r/prometheus-cpp.git",
-    commit = "9c865b1c1a4234fa063e91225bb228111ee922ac",
-    )

+ 133 - 0
repositories.bzl

@@ -0,0 +1,133 @@
+_PROMETHEUS_CLIENT_MODEL_BUILD_FILE = """
+licenses(["notice"])  # BSD license
+
+load("@com_google_protobuf//:protobuf.bzl", "cc_proto_library")
+
+cc_proto_library(
+    name = "prometheus_client_model",
+    srcs = ["metrics.proto"],
+    default_runtime = "@com_google_protobuf//:protobuf",
+    protoc = "@com_google_protobuf//:protoc",
+    visibility = ["//visibility:public"],
+)
+"""
+
+_CIVETWEB_BUILD_FILE = """
+licenses(["notice"])  # MIT license
+
+cc_library(
+    name = "civetweb",
+    srcs = [
+        "src/CivetServer.cpp",
+        "src/civetweb.c",
+    ],
+    hdrs = [
+        "include/CivetServer.h",
+        "include/civetweb.h",
+    ],
+    copts = [
+        "-DUSE_IPV6",
+        "-DNDEBUG",
+        "-DNO_CGI",
+        "-DNO_CACHING",
+        "-DNO_SSL",
+        "-DNO_FILES",
+    ],
+    includes = [
+        "include",
+    ],
+    textual_hdrs = [
+        "src/md5.inl",
+        "src/handle_form.inl",
+    ],
+    visibility = ["//visibility:public"],
+)
+"""
+
+_GOOGLEBENCHEMARK_BUILD_FILE = """
+licenses(["notice"])  # Apache-2.0 license
+
+cc_library(
+    name = "googlebenchmark",
+    srcs = glob(
+        ["src/*.cc"],
+        exclude = [
+            "src/re_posix.cc",
+            "src/gnuregex.cc",
+        ],
+    ),
+    hdrs = glob(
+        [
+            "src/*.h",
+            "include/benchmark/*.h",
+        ],
+        exclude = [
+            "src/re_posix.h",
+            "src/gnuregex.h",
+        ],
+    ),
+    copts = [
+        "-DHAVE_STD_REGEX",
+    ],
+    includes = [
+        "include",
+    ],
+    visibility = ["//visibility:public"],
+)
+"""
+
+def load_civetweb():
+    native.new_http_archive(
+        name = "civetweb",
+        strip_prefix = "civetweb-1.9.1",
+        sha256 = "880d741724fd8de0ebc77bc5d98fa673ba44423dc4918361c3cd5cf80955e36d",
+        urls = [
+           "https://github.com/civetweb/civetweb/archive/v1.9.1.tar.gz",
+       ],
+       build_file_content = _CIVETWEB_BUILD_FILE,
+    )
+
+def load_prometheus_client_model():
+    native.new_git_repository(
+        name = "prometheus_client_model",
+        remote = "https://github.com/prometheus/client_model.git",
+        commit = "e2da43a",
+        build_file_content = _PROMETHEUS_CLIENT_MODEL_BUILD_FILE,
+    )
+
+def load_com_google_protobuf():
+    native.http_archive(
+        name = "com_google_protobuf",
+        sha256 = "8e0236242106e680b4f9f576cc44b8cd711e948b20a9fc07769b0a20ceab9cc4",
+        strip_prefix = "protobuf-3.4.1",
+        urls = [
+            "https://github.com/google/protobuf/archive/v3.4.1.tar.gz",
+        ],
+    )
+
+def load_com_google_googletest():
+    native.http_archive(
+        name = "com_google_googletest",
+        strip_prefix = "googletest-master",
+        urls = [
+            "https://github.com/google/googletest/archive/master.zip",
+        ],
+    )
+
+def load_com_google_googlebenchmark():
+    native.new_http_archive(
+        name = "com_google_googlebenchmark",
+        sha256 = "3dcc90c158838e2ac4a7ad06af9e28eb5877cf28252a81e55eb3c836757d3070",
+        strip_prefix = "benchmark-1.2.0",
+        urls = [
+            "https://github.com/google/benchmark/archive/v1.2.0.tar.gz",
+        ],
+        build_file_content = _GOOGLEBENCHEMARK_BUILD_FILE,
+    )
+
+def prometheus_cpp_repositories():
+    load_com_google_protobuf()
+    load_prometheus_client_model()
+    load_civetweb()
+    load_com_google_googletest()
+    load_com_google_googlebenchmark()

+ 2 - 2
tests/BUILD

@@ -12,7 +12,7 @@ cc_test(
     copts = ["-Iexternal/googletest/include"],
     linkstatic = 1,
     deps = [
-        "//:prometheus-cpp",
-        "@googletest//:main",
+        "//:prometheus_cpp",
+        "@com_google_googletest//:gtest_main",
     ],
 )

+ 2 - 2
tests/benchmark/BUILD

@@ -11,7 +11,7 @@ cc_binary(
     ],
     linkstatic = 1,
     deps = [
-        "//:prometheus-cpp",
-        "@googlebenchmark//:googlebenchmark",
+        "//:prometheus_cpp",
+        "@com_google_googlebenchmark//:googlebenchmark",
     ],
 )

+ 1 - 1
tests/integration/BUILD

@@ -1,7 +1,7 @@
 cc_binary(
     name = "sample-server",
     srcs = ["sample_server.cc"],
-    deps = ["//:prometheus-cpp"],
+    deps = ["//:prometheus_cpp"],
 )
 
 sh_test(

+ 1 - 1
tests/integration/sample_server.cc

@@ -11,7 +11,7 @@ int main(int argc, char** argv) {
   using namespace prometheus;
 
   // create an http server running on port 8080
-  auto&& exposer = Exposer{"127.0.0.1:8080"};
+  Exposer exposer{"127.0.0.1:8080"};
 
   // create a metrics registry with component=main labels applied to all its
   // metrics