Commit 1abf297f authored by Jisi Liu's avatar Jisi Liu

Merge pull request #903 from pherl/bazel_test

Enable python bazel tests and explicit list python dependencies.
parents b152d7fe e1f60f50
...@@ -472,8 +472,6 @@ java_library( ...@@ -472,8 +472,6 @@ java_library(
# Python support # Python support
################################################################################ ################################################################################
# Requires: six for python 2/3 compatibility. `pip install six`
# Hack: # Hack:
# protoc generated files contain imports like: # protoc generated files contain imports like:
# "from google.protobuf.xxx import yyy" # "from google.protobuf.xxx import yyy"
...@@ -485,10 +483,13 @@ java_library( ...@@ -485,10 +483,13 @@ java_library(
# that depend on the target. # that depend on the target.
# #
# If you use python protobuf as a third_party library in your bazel managed # If you use python protobuf as a third_party library in your bazel managed
# project, please import the whole package to //google/protobuf in your # project:
# 1) Please import the whole package to //google/protobuf in your
# project. Otherwise, bazel disallows generated files out of the current # project. Otherwise, bazel disallows generated files out of the current
# package, thus we won't be able to copy protobuf runtime files into # package, thus we won't be able to copy protobuf runtime files into
# //google/protobuf/. # //google/protobuf/.
# 2) The runtime also requires "six" for Python2/3 compatibility, please see the
# WORKSPACE file and bind "six" to your workspace as well.
internal_copied_filegroup( internal_copied_filegroup(
name = "python_srcs", name = "python_srcs",
srcs = glob( srcs = glob(
...@@ -510,6 +511,7 @@ py_proto_library( ...@@ -510,6 +511,7 @@ py_proto_library(
include = "src", include = "src",
protoc = ":protoc", protoc = ":protoc",
py_extra_srcs = [":python_srcs"], py_extra_srcs = [":python_srcs"],
py_libs = ["//external:six"],
visibility = ["//visibility:public"], visibility = ["//visibility:public"],
) )
...@@ -534,7 +536,10 @@ py_proto_library( ...@@ -534,7 +536,10 @@ py_proto_library(
py_proto_library( py_proto_library(
name = "python_specific_test_protos", name = "python_specific_test_protos",
srcs = glob(["python/google/protobuf/internal/*.proto"]), srcs = glob([
"python/google/protobuf/internal/*.proto",
"python/google/protobuf/internal/import_test_package/*.proto",
]),
include = "python", include = "python",
protoc = ":protoc", protoc = ":protoc",
deps = [":python_common_test_protos"], deps = [":python_common_test_protos"],
...@@ -552,6 +557,9 @@ py_library( ...@@ -552,6 +557,9 @@ py_library(
internal_protobuf_py_tests( internal_protobuf_py_tests(
name = "python_tests_batch", name = "python_tests_batch",
data = glob([
"src/google/protobuf/**/*",
]),
modules = [ modules = [
"descriptor_database_test", "descriptor_database_test",
"descriptor_pool_test", "descriptor_pool_test",
...@@ -559,13 +567,13 @@ internal_protobuf_py_tests( ...@@ -559,13 +567,13 @@ internal_protobuf_py_tests(
"generator_test", "generator_test",
"json_format_test", "json_format_test",
"message_factory_test", "message_factory_test",
# "message_test", # failed due to testdata path "message_test",
"proto_builder_test", "proto_builder_test",
# "reflection_test", # failed due to testdata path "reflection_test",
"service_reflection_test", "service_reflection_test",
"symbol_database_test", "symbol_database_test",
"text_encoding_test", "text_encoding_test",
# "text_format_test", # failed due to testdata path "text_format_test",
"unknown_fields_test", "unknown_fields_test",
"wire_format_test", "wire_format_test",
], ],
......
...@@ -5,6 +5,13 @@ new_http_archive( ...@@ -5,6 +5,13 @@ new_http_archive(
build_file = "gmock.BUILD", build_file = "gmock.BUILD",
) )
new_http_archive(
name = "six_archive",
url = "https://pypi.python.org/packages/source/s/six/six-1.10.0.tar.gz#md5=34eed507548117b2ab523ab14b2f8b55",
sha256 = "105f8d68616f8248e24bf0e9372ef04d3cc10104f1980f54d57b2ce73a5ad56a",
build_file = "six.BUILD",
)
bind( bind(
name = "gtest", name = "gtest",
actual = "@gmock_archive//:gtest", actual = "@gmock_archive//:gtest",
...@@ -14,3 +21,8 @@ bind( ...@@ -14,3 +21,8 @@ bind(
name = "gtest_main", name = "gtest_main",
actual = "@gmock_archive//:gtest_main", actual = "@gmock_archive//:gtest_main",
) )
bind(
name = "six",
actual = "@six_archive//:six",
)
genrule(
name = "copy_six",
srcs = ["six-1.10.0/six.py"],
outs = ["six.py"],
cmd = "cp $< $(@)",
)
py_library(
name = "six",
srcs = ["six.py"],
visibility = ["//visibility:public"],
)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment