Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
b0f6035f
Commit
b0f6035f
authored
Dec 19, 2018
by
Hao Nguyen
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/master'
parents
c11096c1
4dec4f93
Hide whitespace changes
Inline
Side-by-side
Showing
67 changed files
with
1120 additions
and
209 deletions
+1120
-209
.gitignore
.gitignore
+2
-0
BUILD
BUILD
+7
-2
PhpBenchmark.php
benchmarks/php/PhpBenchmark.php
+1
-1
py_benchmark.py
benchmarks/python/py_benchmark.py
+4
-3
result_uploader.py
benchmarks/util/result_uploader.py
+4
-4
build.sh
kokoro/linux/32-bit/build.sh
+2
-1
build.sh
kokoro/linux/benchmark/build.sh
+5
-104
run.sh
kokoro/linux/benchmark/run.sh
+105
-0
build_and_run_docker.sh
kokoro/linux/build_and_run_docker.sh
+12
-2
Dockerfile
kokoro/linux/dockerfile/test/php/Dockerfile
+17
-12
Dockerfile
kokoro/linux/dockerfile/test/php_32bit/Dockerfile
+224
-0
Dockerfile
kokoro/linux/dockerfile/test/python_jessie/Dockerfile
+39
-0
Dockerfile
kokoro/linux/dockerfile/test/python_stretch/Dockerfile
+47
-0
build.sh
kokoro/linux/php_all/build.sh
+2
-1
build.sh
kokoro/linux/python27/build.sh
+3
-2
continuous.cfg
kokoro/linux/python27/continuous.cfg
+1
-1
presubmit.cfg
kokoro/linux/python27/presubmit.cfg
+1
-1
build.sh
kokoro/linux/python27_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python27_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python27_cpp/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python33/build.sh
+18
-0
continuous.cfg
kokoro/linux/python33/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python33/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python33_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python33_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python33_cpp/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python34/build.sh
+18
-0
continuous.cfg
kokoro/linux/python34/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python34/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python34_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python34_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python34_cpp/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python35/build.sh
+18
-0
continuous.cfg
kokoro/linux/python35/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python35/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python35_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python35_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python35_cpp/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python36/build.sh
+18
-0
continuous.cfg
kokoro/linux/python36/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python36/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python36_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python36_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python36_cpp/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python37/build.sh
+18
-0
continuous.cfg
kokoro/linux/python37/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python37/presubmit.cfg
+11
-0
build.sh
kokoro/linux/python37_cpp/build.sh
+18
-0
continuous.cfg
kokoro/linux/python37_cpp/continuous.cfg
+11
-0
presubmit.cfg
kokoro/linux/python37_cpp/presubmit.cfg
+11
-0
GPBDescriptor.m
objectivec/GPBDescriptor.m
+2
-3
GPBDescriptorTests.m
objectivec/Tests/GPBDescriptorTests.m
+37
-0
unittest_objc.proto
objectivec/Tests/unittest_objc.proto
+15
-0
message.c
php/ext/google/protobuf/message.c
+0
-26
protobuf.h
php/ext/google/protobuf/protobuf.h
+4
-2
storage.c
php/ext/google/protobuf/storage.c
+4
-2
array_test.php
php/tests/array_test.php
+1
-1
compatibility_test.sh
php/tests/compatibility_test.sh
+4
-0
encode_decode_test.php
php/tests/encode_decode_test.php
+6
-0
generated_class_test.php
php/tests/generated_class_test.php
+10
-0
map_field_test.php
php/tests/map_field_test.php
+1
-1
test_base.php
php/tests/test_base.php
+2
-1
well_known_test.php
php/tests/well_known_test.php
+1
-0
setup.py
python/setup.py
+3
-0
objectivec_enum.cc
src/google/protobuf/compiler/objectivec/objectivec_enum.cc
+23
-0
objectivec_enum.h
src/google/protobuf/compiler/objectivec/objectivec_enum.h
+1
-0
tests.sh
tests.sh
+90
-39
No files found.
.gitignore
View file @
b0f6035f
...
...
@@ -145,7 +145,9 @@ php/ext/google/protobuf/Makefile.objects
php/ext/google/protobuf/acinclude.m4
php/ext/google/protobuf/build/
php/ext/google/protobuf/config.h
php/ext/google/protobuf/config.h.in~
php/ext/google/protobuf/config.nice
php/ext/google/protobuf/configure.ac
php/ext/google/protobuf/configure.in
php/ext/google/protobuf/mkinstalldirs
php/ext/google/protobuf/run-tests.php
...
...
BUILD
View file @
b0f6035f
...
...
@@ -514,7 +514,6 @@ cc_test(
"src/google/protobuf/arena_unittest.cc",
"src/google/protobuf/arenastring_unittest.cc",
"src/google/protobuf/compiler/annotation_test_util.cc",
"src/google/protobuf/compiler/command_line_interface_unittest.cc",
"src/google/protobuf/compiler/cpp/cpp_bootstrap_unittest.cc",
"src/google/protobuf/compiler/cpp/cpp_move_unittest.cc",
"src/google/protobuf/compiler/cpp/cpp_plugin_unittest.cc",
...
...
@@ -583,7 +582,13 @@ cc_test(
"src/google/protobuf/util/type_resolver_util_test.cc",
"src/google/protobuf/well_known_types_unittest.cc",
"src/google/protobuf/wire_format_unittest.cc",
],
] + select({
"//conditions:default" : [
# Doesn't pass on Windows with MSVC
"src/google/protobuf/compiler/command_line_interface_unittest.cc",
],
":msvc": []
}),
copts = COPTS,
data = [
":test_plugin",
...
...
benchmarks/php/PhpBenchmark.php
View file @
b0f6035f
...
...
@@ -62,7 +62,7 @@ class Benchmark
$t
=
$this
->
runBenchmarkWithTimes
(
1
);
$times
=
ceil
(
$this
->
benchmark_time
/
$t
);
return
$this
->
total_bytes
*
$times
/
$this
->
runBenchmarkWithTimes
(
$times
)
*
(
$times
==
1
?
$t
:
$this
->
runBenchmarkWithTimes
(
$times
)
)
*
$this
->
coefficient
;
}
...
...
benchmarks/python/py_benchmark.py
View file @
b0f6035f
...
...
@@ -134,9 +134,10 @@ class Benchmark:
t
=
self
.
dry_run
(
test_method_args
,
setup_method_args
);
if
t
<
3
:
reps
=
int
(
math
.
ceil
(
3
/
t
))
*
self
.
full_iteration
t
=
timeit
.
timeit
(
stmt
=
"
%
s(
%
s)"
%
(
self
.
test_method
,
test_method_args
),
setup
=
self
.
full_setup_code
(
setup_method_args
),
number
=
reps
);
if
reps
!=
self
.
full_iteration
:
t
=
timeit
.
timeit
(
stmt
=
"
%
s(
%
s)"
%
(
self
.
test_method
,
test_method_args
),
setup
=
self
.
full_setup_code
(
setup_method_args
),
number
=
reps
);
return
self
.
total_bytes
*
1.0
/
2
**
20
/
(
1.0
*
t
/
reps
)
...
...
benchmarks/util/result_uploader.py
View file @
b0f6035f
...
...
@@ -61,12 +61,12 @@ def upload_result(result_list, metadata):
new_result
[
"timestamp"
]
=
_INITIAL_TIME
print
(
labels_string
)
bq
=
big_query_utils
.
create_big_query
()
row
=
big_query_utils
.
make_row
(
str
(
uuid
.
uuid4
()),
new_result
)
if
not
big_query_utils
.
insert_rows
(
bq
,
_PROJECT_ID
,
_DATASET
,
bq
=
big_query_utils
.
create_big_query
()
row
=
big_query_utils
.
make_row
(
str
(
uuid
.
uuid4
()),
new_result
)
if
not
big_query_utils
.
insert_rows
(
bq
,
_PROJECT_ID
,
_DATASET
,
_TABLE
+
"$"
+
_NOW
,
[
row
]):
print
(
'Error when uploading result'
,
new_result
)
print
(
'Error when uploading result'
,
new_result
)
if
__name__
==
"__main__"
:
...
...
kokoro/linux/32-bit/build.sh
View file @
b0f6035f
...
...
@@ -10,7 +10,8 @@
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERFILE_DIR
=
kokoro/linux/32-bit
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/php_32bit
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"php_all_32"
...
...
kokoro/linux/benchmark/build.sh
100755 → 100644
View file @
b0f6035f
#!/bin/bash
#
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERFILE_DIR
=
kokoro/linux/64-bit
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
oldpwd
=
`
pwd
`
# tcmalloc
if
[
!
-f
gperftools/.libs/libtcmalloc.so
]
;
then
git clone https://github.com/gperftools/gperftools.git
cd
gperftools
./autogen.sh
./configure
make
-j8
cd
..
fi
# download datasets for benchmark
cd
benchmarks
./download_data.sh
datasets
=
$(for
file
in
$(
find
.
-type
f
-name
"dataset.*.pb"
-not
-path
"./tmp/*"
)
;
do
echo
"
$(
pwd
)
/
$file
"
;
done
| xargs
)
echo
$datasets
cd
$oldpwd
# build Python protobuf
./autogen.sh
./configure
CXXFLAGS
=
"-fPIC -O2"
make
-j8
cd
python
python setup.py build
--cpp_implementation
pip
install
.
--user
# build and run Python benchmark
cd
../benchmarks
make python-pure-python-benchmark
make python-cpp-reflection-benchmark
make
-j8
python-cpp-generated-code-benchmark
echo
"["
>
tmp/python_result.json
echo
"benchmarking pure python..."
./python-pure-python-benchmark
--json
--behavior_prefix
=
"pure-python-benchmark"
$datasets
>>
tmp/python_result.json
echo
","
>>
"tmp/python_result.json"
echo
"benchmarking python cpp reflection..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
./python-cpp-reflection-benchmark
--json
--behavior_prefix
=
"cpp-reflection-benchmark"
$datasets
>>
tmp/python_result.json
echo
","
>>
"tmp/python_result.json"
echo
"benchmarking python cpp generated code..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
./python-cpp-generated-code-benchmark
--json
--behavior_prefix
=
"cpp-generated-code-benchmark"
$datasets
>>
tmp/python_result.json
echo
"]"
>>
"tmp/python_result.json"
cd
$oldpwd
# build CPP protobuf
./configure
make clean
&&
make
-j8
# build Java protobuf
cd
java
mvn package
cd
..
# build CPP benchmark
cd
benchmarks
mv
tmp/python_result.json
.
&&
make clean
&&
make
-j8
cpp-benchmark
&&
mv
python_result.json tmp
echo
"benchmarking cpp..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
./cpp-benchmark
--benchmark_min_time
=
5.0
--benchmark_out_format
=
json
--benchmark_out
=
"tmp/cpp_result.json"
$datasets
cd
$oldpwd
# build go protobuf
export
PATH
=
"
`
pwd
`
/src:
$PATH
"
export
GOPATH
=
"
$HOME
/gocode"
mkdir
-p
"
$GOPATH
/src/github.com/google"
rm
-f
"
$GOPATH
/src/github.com/protocolbuffers/protobuf"
ln
-s
"
`
pwd
`
"
"
$GOPATH
/src/github.com/protocolbuffers/protobuf"
export
PATH
=
"
$GOPATH
/bin:
$PATH
"
go get github.com/golang/protobuf/protoc-gen-go
# build go benchmark
cd
benchmarks
make go-benchmark
echo
"benchmarking go..."
./go-benchmark
$datasets
>
tmp/go_result.txt
# build java benchmark
make java-benchmark
echo
"benchmarking java..."
./java-benchmark
-Cresults
.file.options.file
=
"tmp/java_result.json"
$datasets
make js-benchmark
echo
"benchmarking js..."
./js-benchmark
$datasets
--json_output
=
$(
pwd
)
/tmp/node_result.json
make
-j8
generate_proto3_data
proto3_datasets
=
$(for
file
in
$datasets
;
do
echo
$(
pwd
)
/tmp/proto3_data/
${
file
#
$(
pwd
)}
;
done
| xargs
)
echo
$proto3_datasets
# build php benchmark
make
-j8
php-benchmark
echo
"benchmarking php..."
./php-benchmark
$proto3_datasets
--json
--behavior_prefix
=
"php"
>
tmp/php_result.json
make
-j8
php-c-benchmark
echo
"benchmarking php_c..."
./php-c-benchmark
$proto3_datasets
--json
--behavior_prefix
=
"php_c"
>
tmp/php_c_result.json
# upload result to bq
make python_add_init
env
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
python
-m
util.result_uploader
-php
=
"../tmp/php_result.json"
-php_c
=
"../tmp/php_c_result.json"
\
-cpp
=
"../tmp/cpp_result.json"
-java
=
"../tmp/java_result.json"
-go
=
"../tmp/go_result.txt"
-python
=
"../tmp/python_result.json"
-node
=
"../tmp/node_result.json"
cd
$oldpwd
export
TEST_SET
=
"benchmark"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/benchmark/run.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
OUTPUT_DIR
=
testoutput
oldpwd
=
`
pwd
`
# tcmalloc
if
[
!
-f
gperftools/.libs/libtcmalloc.so
]
;
then
git clone https://github.com/gperftools/gperftools.git
cd
gperftools
./autogen.sh
./configure
make
-j8
cd
..
fi
# download datasets for benchmark
cd
benchmarks
./download_data.sh
datasets
=
$(for
file
in
$(
find
.
-type
f
-name
"dataset.*.pb"
-not
-path
"./tmp/*"
)
;
do
echo
"
$(
pwd
)
/
$file
"
;
done
| xargs
)
echo
$datasets
cd
$oldpwd
# build Python protobuf
./autogen.sh
./configure
CXXFLAGS
=
"-fPIC -O2"
make
-j8
cd
python
python setup.py build
--cpp_implementation
pip
install
.
--user
# build and run Python benchmark
cd
../benchmarks
make python-pure-python-benchmark
make python-cpp-reflection-benchmark
make
-j8
python-cpp-generated-code-benchmark
echo
"["
>
tmp/python_result.json
echo
"benchmarking pure python..."
./python-pure-python-benchmark
--json
--behavior_prefix
=
"pure-python-benchmark"
$datasets
>>
tmp/python_result.json
echo
","
>>
"tmp/python_result.json"
echo
"benchmarking python cpp reflection..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
./python-cpp-reflection-benchmark
--json
--behavior_prefix
=
"cpp-reflection-benchmark"
$datasets
>>
tmp/python_result.json
echo
","
>>
"tmp/python_result.json"
echo
"benchmarking python cpp generated code..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
./python-cpp-generated-code-benchmark
--json
--behavior_prefix
=
"cpp-generated-code-benchmark"
$datasets
>>
tmp/python_result.json
echo
"]"
>>
"tmp/python_result.json"
cd
$oldpwd
# build CPP protobuf
./configure
make clean
&&
make
-j8
# build Java protobuf
cd
java
mvn package
cd
..
# build CPP benchmark
cd
benchmarks
mv
tmp/python_result.json
.
&&
make clean
&&
make
-j8
cpp-benchmark
&&
mv
python_result.json tmp
echo
"benchmarking cpp..."
env
LD_PRELOAD
=
"
$oldpwd
/gperftools/.libs/libtcmalloc.so"
./cpp-benchmark
--benchmark_min_time
=
5.0
--benchmark_out_format
=
json
--benchmark_out
=
"tmp/cpp_result.json"
$datasets
cd
$oldpwd
# build go protobuf
export
PATH
=
"
`
pwd
`
/src:
$PATH
"
export
GOPATH
=
"
$HOME
/gocode"
mkdir
-p
"
$GOPATH
/src/github.com/google"
rm
-f
"
$GOPATH
/src/github.com/protocolbuffers/protobuf"
ln
-s
"
`
pwd
`
"
"
$GOPATH
/src/github.com/protocolbuffers/protobuf"
export
PATH
=
"
$GOPATH
/bin:
$PATH
"
go get github.com/golang/protobuf/protoc-gen-go
# build go benchmark
cd
benchmarks
make go-benchmark
echo
"benchmarking go..."
./go-benchmark
$datasets
>
tmp/go_result.txt
# build java benchmark
make java-benchmark
echo
"benchmarking java..."
./java-benchmark
-Cresults
.file.options.file
=
"tmp/java_result.json"
$datasets
make js-benchmark
echo
"benchmarking js..."
./js-benchmark
$datasets
--json_output
=
$(
pwd
)
/tmp/node_result.json
make
-j8
generate_proto3_data
proto3_datasets
=
$(for
file
in
$datasets
;
do
echo
$(
pwd
)
/tmp/proto3_data/
${
file
#
$(
pwd
)}
;
done
| xargs
)
echo
$proto3_datasets
# build php benchmark
make
-j8
php-c-benchmark
echo
"benchmarking php_c..."
./php-c-benchmark
$proto3_datasets
--json
--behavior_prefix
=
"php_c"
>
tmp/php_c_result.json
# upload result to bq
make python_add_init
env
LD_LIBRARY_PATH
=
"
$oldpwd
/src/.libs"
python
-m
util.result_uploader
-php_c
=
"../tmp/php_c_result.json"
\
-cpp
=
"../tmp/cpp_result.json"
-java
=
"../tmp/java_result.json"
-go
=
"../tmp/go_result.txt"
-python
=
"../tmp/python_result.json"
-node
=
"../tmp/node_result.json"
cd
$oldpwd
kokoro/linux/build_and_run_docker.sh
View file @
b0f6035f
...
...
@@ -3,6 +3,8 @@
# Builds docker image and runs a command under it.
# This is a generic script that is configured with the following variables:
#
# DOCKERHUB_ORGANIZATION - The organization on docker hub storing the
# Dockerfile.
# DOCKERFILE_DIR - Directory in which Dockerfile file is located.
# DOCKER_RUN_SCRIPT - Script to run under docker (relative to protobuf repo root)
# OUTPUT_DIR - Directory that will be copied from inside docker after finishing.
...
...
@@ -15,8 +17,16 @@ git_root=$(pwd)
cd
-
# Use image name based on Dockerfile sha1
DOCKERHUB_ORGANIZATION
=
grpctesting/protobuf
DOCKER_IMAGE_NAME
=
${
DOCKERHUB_ORGANIZATION
}
_
$(
sha1sum
$DOCKERFILE_DIR
/Dockerfile |
cut
-f1
-d
\
)
if
[
-z
"
$DOCKERHUB_ORGANIZATION
"
]
then
DOCKERHUB_ORGANIZATION
=
grpctesting/protobuf
DOCKER_IMAGE_NAME
=
${
DOCKERHUB_ORGANIZATION
}
_
$(
sha1sum
$DOCKERFILE_DIR
/Dockerfile |
cut
-f1
-d
\
)
else
# TODO(teboring): Remove this when all tests have been migrated to separate
# docker images.
DOCKERFILE_PREFIX
=
$(
basename
$DOCKERFILE_DIR
)
DOCKER_IMAGE_NAME
=
${
DOCKERHUB_ORGANIZATION
}
/
${
DOCKERFILE_PREFIX
}
_
$(
sha1sum
$DOCKERFILE_DIR
/Dockerfile |
cut
-f1
-d
\
)
fi
# Pull dockerimage from Dockerhub
docker pull
$DOCKER_IMAGE_NAME
...
...
kokoro/linux/dockerfile/test/php/Dockerfile
View file @
b0f6035f
...
...
@@ -79,8 +79,8 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-4.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-5.5
\
&&
mv
phpunit /usr/local/php-5.5-zts
&&
cp
phpunit /usr/local/php-5.5
/bin
\
&&
mv
phpunit /usr/local/php-5.5-zts
/bin
# php 5.6
RUN
cd
php-src
\
...
...
@@ -109,8 +109,8 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-5.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-5.6
\
&&
mv
phpunit /usr/local/php-5.6-zts
&&
cp
phpunit /usr/local/php-5.6
/bin
\
&&
mv
phpunit /usr/local/php-5.6-zts
/bin
# php 7.0
RUN
cd
php-src
\
...
...
@@ -139,8 +139,8 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-6.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.0
\
&&
mv
phpunit /usr/local/php-7.0-zts
&&
cp
phpunit /usr/local/php-7.0
/bin
\
&&
mv
phpunit /usr/local/php-7.0-zts
/bin
# php 7.1
RUN
cd
php-src
\
...
...
@@ -169,8 +169,8 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.1
\
&&
mv
phpunit /usr/local/php-7.1-zts
&&
cp
phpunit /usr/local/php-7.1
/bin
\
&&
mv
phpunit /usr/local/php-7.1-zts
/bin
# php 7.2
RUN
cd
php-src
\
...
...
@@ -199,8 +199,8 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.2
\
&&
mv
phpunit /usr/local/php-7.2-zts
&&
cp
phpunit /usr/local/php-7.2
/bin
\
&&
mv
phpunit /usr/local/php-7.2-zts
/bin
# php 7.3
RUN
cd
php-src
\
...
...
@@ -229,5 +229,10 @@ RUN cd php-src \
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.3
\
&&
mv
phpunit /usr/local/php-7.3-zts
&&
cp
phpunit /usr/local/php-7.3/bin
\
&&
mv
phpunit /usr/local/php-7.3-zts/bin
# Install php dependencies
RUN
apt-get clean
&&
apt-get update
&&
apt-get
install
-y
--force-yes
\
valgrind
\
&&
apt-get clean
kokoro/linux/dockerfile/test/php_32bit/Dockerfile
0 → 100644
View file @
b0f6035f
FROM
32bit/debian:jessie
# Install dependencies. We start with the basic ones require to build protoc
# and the C++ build
RUN
apt-get update
&&
apt-get
install
-y
\
autoconf
\
autotools-dev
\
build-essential
\
bzip2
\
ccache
\
curl
\
gcc
\
git
\
libc6
\
libc6-dbg
\
libc6-dev
\
libgtest-dev
\
libtool
\
make
\
parallel
\
time
\
wget
\
&&
apt-get clean
# Install php dependencies
RUN
apt-get clean
&&
apt-get update
&&
apt-get
install
-y
--force-yes
\
bison
\
php5
\
libcurl4-openssl-dev
\
libssl-dev
\
libxml2-dev
\
unzip
\
zlib1g-dev
\
pkg-config
\
&&
apt-get clean
# Install other dependencies
RUN
wget http://ftp.gnu.org/gnu/bison/bison-2.6.4.tar.gz
-O
/var/local/bison-2.6.4.tar.gz
RUN
cd
/var/local
\
&&
tar
-zxvf
bison-2.6.4.tar.gz
\
&&
cd
/var/local/bison-2.6.4
\
&&
./configure
\
&&
make
\
&&
make
install
# Install composer
RUN
curl
-sS
https://getcomposer.org/installer | php
RUN
mv
composer.phar /usr/local/bin/composer
# Download php source code
RUN
git clone https://github.com/php/php-src
# php 5.5
RUN
cd
php-src
\
&&
git checkout PHP-5.5.38
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-5.5
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-5.5-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-4.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-5.5/bin
\
&&
mv
phpunit /usr/local/php-5.5-zts/bin
# php 5.6
RUN
cd
php-src
\
&&
git checkout PHP-5.6.39
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-5.6
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-5.6-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-5.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-5.6/bin
\
&&
mv
phpunit /usr/local/php-5.6-zts/bin
# php 7.0
RUN
cd
php-src
\
&&
git checkout PHP-7.0.33
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.0
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.0-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-6.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.0/bin
\
&&
mv
phpunit /usr/local/php-7.0-zts/bin
# php 7.1
RUN
cd
php-src
\
&&
git checkout PHP-7.1.25
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.1
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.1-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.1/bin
\
&&
mv
phpunit /usr/local/php-7.1-zts/bin
# php 7.2
RUN
cd
php-src
\
&&
git checkout PHP-7.2.13
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.2
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.2-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.2/bin
\
&&
mv
phpunit /usr/local/php-7.2-zts/bin
# php 7.3
RUN
cd
php-src
\
&&
git checkout PHP-7.3.0
\
&&
./buildconf
--force
RUN
cd
php-src
\
&&
./configure
\
--enable-bcmath
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.3
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
cd
php-src
\
&&
./configure
\
--enable-maintainer-zts
\
--with-openssl
\
--with-zlib
\
--prefix
=
/usr/local/php-7.3-zts
\
&&
make
\
&&
make
install
\
&&
make clean
RUN
wget
-O
phpunit https://phar.phpunit.de/phpunit-7.phar
\
&&
chmod
+x phpunit
\
&&
cp
phpunit /usr/local/php-7.3/bin
\
&&
mv
phpunit /usr/local/php-7.3-zts/bin
# Install php dependencies
RUN
apt-get clean
&&
apt-get update
&&
apt-get
install
-y
--force-yes
\
valgrind
\
&&
apt-get clean
kokoro/linux/dockerfile/test/python_jessie/Dockerfile
0 → 100644
View file @
b0f6035f
FROM
debian:jessie
# Install dependencies. We start with the basic ones require to build protoc
# and the C++ build
RUN
apt-get update
&&
apt-get
install
-y
\
autoconf
\
autotools-dev
\
build-essential
\
bzip2
\
ccache
\
curl
\
gcc
\
git
\
libc6
\
libc6-dbg
\
libc6-dev
\
libgtest-dev
\
libtool
\
make
\
parallel
\
time
\
wget
\
&&
apt-get clean
# Install python dependencies
RUN
apt-get update
&&
apt-get
install
-y
\
python-setuptools
\
python-all-dev
\
python3-all-dev
\
python-pip
# Install Python packages from PyPI
RUN
pip
install
--upgrade
pip
==
10.0.1
RUN
pip
install
virtualenv
RUN
pip
install
six
==
1.10.0
twisted
==
17.5.0
# Install pip and virtualenv for Python 3.4
RUN
curl https://bootstrap.pypa.io/get-pip.py | python3.4
RUN
python3.4
-m
pip
install
virtualenv
kokoro/linux/dockerfile/test/python_stretch/Dockerfile
0 → 100644
View file @
b0f6035f
FROM
debian:stretch
# Install dependencies. We start with the basic ones require to build protoc
# and the C++ build
RUN
apt-get update
&&
apt-get
install
-y
\
autoconf
\
autotools-dev
\
build-essential
\
bzip2
\
ccache
\
curl
\
gcc
\
git
\
libc6
\
libc6-dbg
\
libc6-dev
\
libgtest-dev
\
libtool
\
make
\
parallel
\
time
\
wget
\
&&
apt-get clean
# Install Python 2.7
RUN
apt-get update
&&
apt-get
install
-y
python2.7 python-all-dev
RUN
curl https://bootstrap.pypa.io/get-pip.py | python2.7
# Install python dependencies
RUN
apt-get update
&&
apt-get
install
-y
\
python-setuptools
\
python-pip
# Add Debian 'testing' repository
RUN
echo
'deb http://ftp.de.debian.org/debian testing main'
>>
/etc/apt/sources.list
RUN
echo
'APT::Default-Release "stable";'
|
tee
-a
/etc/apt/apt.conf.d/00local
# Install Python3
RUN
apt-get update
&&
apt-get
-t
testing
install
-y
\
python3.5
\
python3.6
\
python3.7
\
python3-all-dev
RUN
curl https://bootstrap.pypa.io/get-pip.py | python3.5
RUN
curl https://bootstrap.pypa.io/get-pip.py | python3.6
RUN
curl https://bootstrap.pypa.io/get-pip.py | python3.7
kokoro/linux/php_all/build.sh
View file @
b0f6035f
...
...
@@ -10,7 +10,8 @@
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERFILE_DIR
=
kokoro/linux/64-bit
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/php
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"php_all"
...
...
kokoro/linux/
64-bit
/build.sh
→
kokoro/linux/
python27
/build.sh
View file @
b0f6035f
...
...
@@ -10,8 +10,9 @@
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERFILE_DIR
=
kokoro/linux/64-bit
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"
csharp java_jdk7 javanano_jdk7 java_oracle7 javanano_oracle7 python python_cpp ruby_all javascript golang php_all
"
export
TEST_SET
=
"
python27
"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/
64-bit
/continuous.cfg
→
kokoro/linux/
python27
/continuous.cfg
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/
64-bit
/build.sh"
build_file: "protobuf/kokoro/linux/
python
/build.sh"
timeout_mins: 120
action {
...
...
kokoro/linux/
64-bit
/presubmit.cfg
→
kokoro/linux/
python27
/presubmit.cfg
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/
64-bit
/build.sh"
build_file: "protobuf/kokoro/linux/
python
/build.sh"
timeout_mins: 120
action {
...
...
kokoro/linux/python27_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python27_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python27_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python27_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python33/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python33"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python33/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python33/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python33_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python33_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python33_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python33_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python34/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python34"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python34/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python34/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python34_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_jessie
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python34_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python34_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python34_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python35/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python35"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python35/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python35/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python35_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python35_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python35_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python35_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python36/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python36"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python36/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python36/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python36_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python36_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python36_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python36_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python37/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python37"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python37/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python37/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python37_cpp/build.sh
0 → 100755
View file @
b0f6035f
#!/bin/bash
#
# This is the top-level script we give to Kokoro as the entry point for
# running the "pull request" project:
#
# This script selects a specific Dockerfile (for building a Docker image) and
# a script to run inside that image. Then we delegate to the general
# build_and_run_docker.sh script.
# Change to repo root
cd
$(
dirname
$0
)
/../../..
export
DOCKERHUB_ORGANIZATION
=
protobuftesting
export
DOCKERFILE_DIR
=
kokoro/linux/dockerfile/test/python_stretch
export
DOCKER_RUN_SCRIPT
=
kokoro/linux/pull_request_in_docker.sh
export
OUTPUT_DIR
=
testoutput
export
TEST_SET
=
"python37_cpp"
./kokoro/linux/build_and_run_docker.sh
kokoro/linux/python37_cpp/continuous.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
kokoro/linux/python37_cpp/presubmit.cfg
0 → 100644
View file @
b0f6035f
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/linux/python_cpp/build.sh"
timeout_mins: 120
action {
define_artifacts {
regex: "**/sponge_log.xml"
}
}
objectivec/GPBDescriptor.m
View file @
b0f6035f
...
...
@@ -872,11 +872,10 @@ uint32_t GPBFieldAlternateTag(GPBFieldDescriptor *self) {
if
(
nameOffsets_
==
NULL
)
return
NO
;
for
(
uint32_t
i
=
0
;
i
<
valueCount_
;
++
i
)
{
int32_t
value
=
values_
[
i
];
NSString
*
valueTextFormatName
=
[
self
textFormatNameForValue
:
value
];
NSString
*
valueTextFormatName
=
[
self
getEnumTextFormatNameForIndex
:
i
];
if
([
valueTextFormatName
isEqual
:
textFormatName
])
{
if
(
outValue
)
{
*
outValue
=
value
;
*
outValue
=
value
s_
[
i
]
;
}
return
YES
;
}
...
...
objectivec/Tests/GPBDescriptorTests.m
View file @
b0f6035f
...
...
@@ -244,7 +244,44 @@
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumName
:
enumName
]);
XCTAssertEqual
(
value
,
2
);
XCTAssertEqualObjects
([
descriptor
getEnumTextFormatNameForIndex
:
4
],
@"BAR2"
);
}
-
(
void
)
testEnumAliasNameCollisions
{
GPBEnumDescriptor
*
descriptor
=
TestEnumObjCNameCollision_EnumDescriptor
();
NSString
*
textFormatName
;
int32_t
value
;
XCTAssertEqual
(
descriptor
.
enumNameCount
,
5U
);
XCTAssertEqualObjects
([
descriptor
getEnumNameForIndex
:
0
],
@"TestEnumObjCNameCollision_Foo"
);
textFormatName
=
[
descriptor
getEnumTextFormatNameForIndex
:
0
];
XCTAssertEqualObjects
(
textFormatName
,
@"FOO"
);
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumTextFormatName
:
textFormatName
]);
XCTAssertEqual
(
value
,
1
);
XCTAssertEqualObjects
([
descriptor
getEnumNameForIndex
:
1
],
@"TestEnumObjCNameCollision_Foo"
);
textFormatName
=
[
descriptor
getEnumTextFormatNameForIndex
:
1
];
XCTAssertEqualObjects
(
textFormatName
,
@"foo"
);
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumTextFormatName
:
textFormatName
]);
XCTAssertEqual
(
value
,
1
);
XCTAssertEqualObjects
([
descriptor
getEnumNameForIndex
:
2
],
@"TestEnumObjCNameCollision_Bar"
);
textFormatName
=
[
descriptor
getEnumTextFormatNameForIndex
:
2
];
XCTAssertEqualObjects
(
textFormatName
,
@"BAR"
);
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumTextFormatName
:
textFormatName
]);
XCTAssertEqual
(
value
,
2
);
XCTAssertEqualObjects
([
descriptor
getEnumNameForIndex
:
3
],
@"TestEnumObjCNameCollision_Mumble"
);
textFormatName
=
[
descriptor
getEnumTextFormatNameForIndex
:
3
];
XCTAssertEqualObjects
(
textFormatName
,
@"mumble"
);
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumTextFormatName
:
textFormatName
]);
XCTAssertEqual
(
value
,
2
);
XCTAssertEqualObjects
([
descriptor
getEnumNameForIndex
:
4
],
@"TestEnumObjCNameCollision_Mumble"
);
textFormatName
=
[
descriptor
getEnumTextFormatNameForIndex
:
4
];
XCTAssertEqualObjects
(
textFormatName
,
@"MUMBLE"
);
XCTAssertTrue
([
descriptor
getValue
:
&
value
forEnumTextFormatName
:
textFormatName
]);
XCTAssertEqual
(
value
,
2
);
}
-
(
void
)
testEnumValueValidator
{
...
...
objectivec/Tests/unittest_objc.proto
View file @
b0f6035f
...
...
@@ -867,3 +867,18 @@ message BoolOnlyMessage {
message
WKTRefereceMessage
{
optional
google.protobuf.Any
an_any
=
1
;
}
// This is in part a compile test, it ensures that when aliases end up with
// the same ObjC name, we drop them to avoid the duplication names. There
// is a test to ensure the descriptors are still generated to support
// reflection and TextFormat.
enum
TestEnumObjCNameCollision
{
option
allow_alias
=
true
;
FOO
=
1
;
foo
=
1
;
BAR
=
2
;
mumble
=
2
;
MUMBLE
=
2
;
}
php/ext/google/protobuf/message.c
View file @
b0f6035f
...
...
@@ -1231,7 +1231,6 @@ zend_class_entry* any_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Any"
,
Any
,
any
)
zend_class_implements
(
any_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_string
(
any_type
,
"type_url"
,
strlen
(
"type_url"
),
""
,
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_string
(
any_type
,
"value"
,
strlen
(
"value"
),
...
...
@@ -1421,7 +1420,6 @@ zend_class_entry* duration_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Duration"
,
Duration
,
duration
)
zend_class_implements
(
duration_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_long
(
duration_type
,
"seconds"
,
strlen
(
"seconds"
),
0
,
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_long
(
duration_type
,
"nanos"
,
strlen
(
"nanos"
),
...
...
@@ -1457,7 +1455,6 @@ zend_class_entry* timestamp_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Timestamp"
,
Timestamp
,
timestamp
)
zend_class_implements
(
timestamp_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_long
(
timestamp_type
,
"seconds"
,
strlen
(
"seconds"
),
0
,
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_long
(
timestamp_type
,
"nanos"
,
strlen
(
"nanos"
),
...
...
@@ -1650,7 +1647,6 @@ zend_class_entry* api_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Api"
,
Api
,
api
)
zend_class_implements
(
api_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
api_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
api_type
,
"methods"
,
strlen
(
"methods"
),
...
...
@@ -1697,7 +1693,6 @@ zend_class_entry* bool_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
BoolValue"
,
BoolValue
,
bool_value
)
zend_class_implements
(
bool_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
bool_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -1726,7 +1721,6 @@ zend_class_entry* bytes_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
BytesValue"
,
BytesValue
,
bytes_value
)
zend_class_implements
(
bytes_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
bytes_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -1755,7 +1749,6 @@ zend_class_entry* double_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
DoubleValue"
,
DoubleValue
,
double_value
)
zend_class_implements
(
double_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
double_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -1792,7 +1785,6 @@ zend_class_entry* enum_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Enum"
,
Enum
,
enum
)
zend_class_implements
(
enum_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
enum_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
enum_type
,
"enumvalue"
,
strlen
(
"enumvalue"
),
...
...
@@ -1837,7 +1829,6 @@ zend_class_entry* enum_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
EnumValue"
,
EnumValue
,
enum_value
)
zend_class_implements
(
enum_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
enum_value_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
enum_value_type
,
"number"
,
strlen
(
"number"
),
...
...
@@ -1872,7 +1863,6 @@ zend_class_entry* field_mask_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
FieldMask"
,
FieldMask
,
field_mask
)
zend_class_implements
(
field_mask_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
field_mask_type
,
"paths"
,
strlen
(
"paths"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -1919,7 +1909,6 @@ zend_class_entry* field_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Field"
,
Field
,
field
)
zend_class_implements
(
field_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
field_type
,
"kind"
,
strlen
(
"kind"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
field_type
,
"cardinality"
,
strlen
(
"cardinality"
),
...
...
@@ -1975,7 +1964,6 @@ zend_class_entry* float_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
FloatValue"
,
FloatValue
,
float_value
)
zend_class_implements
(
float_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
float_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2002,7 +1990,6 @@ zend_class_entry* empty_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
GPBEmpty"
,
GPBEmpty
,
empty
)
zend_class_implements
(
empty_type
TSRMLS_CC
,
1
,
message_type
);
PHP_PROTO_INIT_SUBMSGCLASS_END
PHP_METHOD
(
GPBEmpty
,
__construct
)
{
...
...
@@ -2028,7 +2015,6 @@ zend_class_entry* int32_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Int32Value"
,
Int32Value
,
int32_value
)
zend_class_implements
(
int32_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
int32_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2057,7 +2043,6 @@ zend_class_entry* int64_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Int64Value"
,
Int64Value
,
int64_value
)
zend_class_implements
(
int64_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
int64_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2086,7 +2071,6 @@ zend_class_entry* list_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
ListValue"
,
ListValue
,
list_value
)
zend_class_implements
(
list_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
list_value_type
,
"values"
,
strlen
(
"values"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2127,7 +2111,6 @@ zend_class_entry* method_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Method"
,
Method
,
method
)
zend_class_implements
(
method_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
method_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
method_type
,
"request_type_url"
,
strlen
(
"request_type_url"
),
...
...
@@ -2176,7 +2159,6 @@ zend_class_entry* mixin_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Mixin"
,
Mixin
,
mixin
)
zend_class_implements
(
mixin_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
mixin_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
mixin_type
,
"root"
,
strlen
(
"root"
),
...
...
@@ -2210,7 +2192,6 @@ zend_class_entry* option_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Option"
,
Option
,
option
)
zend_class_implements
(
option_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
option_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
option_type
,
"value"
,
strlen
(
"value"
),
...
...
@@ -2242,7 +2223,6 @@ zend_class_entry* source_context_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
SourceContext"
,
SourceContext
,
source_context
)
zend_class_implements
(
source_context_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
source_context_type
,
"file_name"
,
strlen
(
"file_name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2271,7 +2251,6 @@ zend_class_entry* string_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
StringValue"
,
StringValue
,
string_value
)
zend_class_implements
(
string_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
string_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2300,7 +2279,6 @@ zend_class_entry* struct_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Struct"
,
Struct
,
struct
)
zend_class_implements
(
struct_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
struct_type
,
"fields"
,
strlen
(
"fields"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2339,7 +2317,6 @@ zend_class_entry* type_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Type"
,
Type
,
type
)
zend_class_implements
(
type_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
type_type
,
"name"
,
strlen
(
"name"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
zend_declare_property_null
(
type_type
,
"fields"
,
strlen
(
"fields"
),
...
...
@@ -2383,7 +2360,6 @@ zend_class_entry* u_int32_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
UInt32Value"
,
UInt32Value
,
u_int32_value
)
zend_class_implements
(
u_int32_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
u_int32_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2412,7 +2388,6 @@ zend_class_entry* u_int64_value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
UInt64Value"
,
UInt64Value
,
u_int64_value
)
zend_class_implements
(
u_int64_value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
u_int64_value_type
,
"value"
,
strlen
(
"value"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
@@ -2452,7 +2427,6 @@ zend_class_entry* value_type;
// Init class entry.
PHP_PROTO_INIT_SUBMSGCLASS_START
(
"Google
\\
Protobuf
\\
Value"
,
Value
,
value
)
zend_class_implements
(
value_type
TSRMLS_CC
,
1
,
message_type
);
zend_declare_property_null
(
value_type
,
"kind"
,
strlen
(
"kind"
),
ZEND_ACC_PRIVATE
TSRMLS_CC
);
PHP_PROTO_INIT_SUBMSGCLASS_END
...
...
php/ext/google/protobuf/protobuf.h
View file @
b0f6035f
...
...
@@ -137,7 +137,8 @@
const char* class_name = CLASSNAME; \
INIT_CLASS_ENTRY_EX(class_type, CLASSNAME, strlen(CLASSNAME), \
LOWWERNAME##_methods); \
LOWWERNAME##_type = zend_register_internal_class(&class_type TSRMLS_CC); \
LOWWERNAME##_type = zend_register_internal_class_ex( \
&class_type, message_type, NULL TSRMLS_CC); \
LOWWERNAME##_type->create_object = message_create; \
zend_do_inheritance(LOWWERNAME##_type, message_type TSRMLS_CC);
#define PHP_PROTO_INIT_SUBMSGCLASS_END \
...
...
@@ -404,7 +405,8 @@ static inline int php_proto_zend_hash_get_current_data_ex(HashTable* ht,
const char* class_name = CLASSNAME; \
INIT_CLASS_ENTRY_EX(class_type, CLASSNAME, strlen(CLASSNAME), \
LOWWERNAME##_methods); \
LOWWERNAME##_type = zend_register_internal_class(&class_type TSRMLS_CC); \
LOWWERNAME##_type = zend_register_internal_class_ex( \
&class_type, message_type TSRMLS_CC); \
zend_do_inheritance(LOWWERNAME##_type, message_type TSRMLS_CC);
#define PHP_PROTO_INIT_SUBMSGCLASS_END \
}
...
...
php/ext/google/protobuf/storage.c
View file @
b0f6035f
...
...
@@ -180,7 +180,8 @@ bool native_slot_set_by_array(upb_fieldtype_t type,
PHP_PROTO_ZVAL_STRINGL
(
DEREF
(
memory
,
zval
*
),
Z_STRVAL_P
(
value
),
Z_STRLEN_P
(
value
),
1
);
#else
*
(
zend_string
**
)
memory
=
zend_string_dup
(
Z_STR_P
(
value
),
0
);
*
(
zend_string
**
)
memory
=
zend_string_init
(
Z_STRVAL_P
(
value
),
Z_STRLEN_P
(
value
),
0
);
#endif
break
;
}
...
...
@@ -231,7 +232,8 @@ bool native_slot_set_by_map(upb_fieldtype_t type, const zend_class_entry* klass,
PHP_PROTO_ZVAL_STRINGL
(
DEREF
(
memory
,
zval
*
),
Z_STRVAL_P
(
value
),
Z_STRLEN_P
(
value
),
1
);
#else
*
(
zend_string
**
)
memory
=
zend_string_dup
(
Z_STR_P
(
value
),
0
);
*
(
zend_string
**
)
memory
=
zend_string_init
(
Z_STRVAL_P
(
value
),
Z_STRLEN_P
(
value
),
0
);
#endif
break
;
}
...
...
php/tests/array_test.php
View file @
b0f6035f
...
...
@@ -7,7 +7,7 @@ use Google\Protobuf\Internal\GPBType;
use
Foo\TestMessage
;
use
Foo\TestMessage\Sub
;
class
RepeatedFieldTest
extends
PHPUnit_Framework_
TestCase
class
RepeatedFieldTest
extends
\PHPUnit\Framework\
TestCase
{
#########################################################
...
...
php/tests/compatibility_test.sh
View file @
b0f6035f
...
...
@@ -123,8 +123,12 @@ tests=( array_test.php encode_decode_test.php generated_class_test.php map_field
sed
-i
.bak
'/php_implementation_test.php/d'
phpunit.xml
sed
-i
.bak
'/generated_phpdoc_test.php/d'
phpunit.xml
sed
-i
.bak
's/generated_phpdoc_test.php//g'
tests/test.sh
sed
-i
.bak
's/generated_service_test.php//g'
tests/test.sh
sed
-i
.bak
'/memory_leak_test.php/d'
tests/test.sh
sed
-i
.bak
'/^ public function testTimestamp()$/,/^ }$/d'
tests/well_known_test.php
sed
-i
.bak
's/PHPUnit_Framework_TestCase/\\PHPUnit\\Framework\\TestCase/g'
tests/array_test.php
sed
-i
.bak
's/PHPUnit_Framework_TestCase/\\PHPUnit\\Framework\\TestCase/g'
tests/map_field_test.php
sed
-i
.bak
's/PHPUnit_Framework_TestCase/\\PHPUnit\\Framework\\TestCase/g'
tests/test_base.php
for
t
in
"
${
tests
[@]
}
"
do
remove_error_test tests/
$t
...
...
php/tests/encode_decode_test.php
View file @
b0f6035f
...
...
@@ -31,6 +31,7 @@ class EncodeDecodeTest extends TestBase
{
$m
=
new
TestMessage
();
$m
->
mergeFromJsonString
(
"
{
\"optionalInt32\":1
}
"
);
$this
->
assertEquals
(
1
,
$m
->
getOptionalInt32
());
}
public
function
testDecodeTopLevelBoolValue
()
...
...
@@ -276,6 +277,7 @@ class EncodeDecodeTest extends TestBase
$to
=
new
TestPackedMessage
();
$to
->
mergeFromString
(
TestUtil
::
getGoldenTestPackedMessage
());
TestUtil
::
assertTestPackedMessage
(
$to
);
$this
->
assertTrue
(
true
);
}
public
function
testPackedDecodeUnpacked
()
...
...
@@ -283,6 +285,7 @@ class EncodeDecodeTest extends TestBase
$to
=
new
TestPackedMessage
();
$to
->
mergeFromString
(
TestUtil
::
getGoldenTestUnpackedMessage
());
TestUtil
::
assertTestPackedMessage
(
$to
);
$this
->
assertTrue
(
true
);
}
public
function
testUnpackedEncode
()
...
...
@@ -298,6 +301,7 @@ class EncodeDecodeTest extends TestBase
$to
=
new
TestUnpackedMessage
();
$to
->
mergeFromString
(
TestUtil
::
getGoldenTestPackedMessage
());
TestUtil
::
assertTestPackedMessage
(
$to
);
$this
->
assertTrue
(
true
);
}
public
function
testUnpackedDecodeUnpacked
()
...
...
@@ -305,6 +309,7 @@ class EncodeDecodeTest extends TestBase
$to
=
new
TestUnpackedMessage
();
$to
->
mergeFromString
(
TestUtil
::
getGoldenTestUnpackedMessage
());
TestUtil
::
assertTestPackedMessage
(
$to
);
$this
->
assertTrue
(
true
);
}
public
function
testDecodeInt64
()
...
...
@@ -361,6 +366,7 @@ class EncodeDecodeTest extends TestBase
$data
=
hex2bin
(
'c80501'
);
$m
=
new
TestMessage
();
$m
->
mergeFromString
(
$data
);
$this
->
assertTrue
(
true
);
}
public
function
testEncodeNegativeInt32
()
...
...
php/tests/generated_class_test.php
View file @
b0f6035f
...
...
@@ -260,12 +260,14 @@ class GeneratedClassTest extends TestBase
{
$m
=
new
TestMessage
();
$m
->
setOptionalNestedEnum
(
NestedEnum
::
ZERO
);
$this
->
assertTrue
(
true
);
}
public
function
testLegacyNestedEnum
()
{
$m
=
new
TestMessage
();
$m
->
setOptionalNestedEnum
(
\Foo\TestMessage_NestedEnum
::
ZERO
);
$this
->
assertTrue
(
true
);
}
public
function
testLegacyTypehintWithNestedEnums
()
...
...
@@ -405,6 +407,7 @@ class GeneratedClassTest extends TestBase
$m
=
new
TestMessage
();
$hex
=
hex2bin
(
"ff"
);
$m
->
setOptionalBytes
(
$hex
);
$this
->
assertTrue
(
true
);
}
#########################################################
...
...
@@ -709,6 +712,8 @@ class GeneratedClassTest extends TestBase
// test nested messages
$sub
=
new
NoNamespaceMessage\NestedMessage
();
$n
->
setNestedMessage
(
$sub
);
$this
->
assertTrue
(
true
);
}
public
function
testEnumWithoutNamespace
()
...
...
@@ -718,6 +723,7 @@ class GeneratedClassTest extends TestBase
$repeatedNoNamespaceEnum
=
$m
->
getRepeatedNoNamespaceEnum
();
$repeatedNoNamespaceEnum
[]
=
NoNameSpaceEnum
::
VALUE_A
;
$m
->
setRepeatedNoNamespaceEnum
(
$repeatedNoNamespaceEnum
);
$this
->
assertTrue
(
true
);
}
#########################################################
...
...
@@ -1262,6 +1268,8 @@ class GeneratedClassTest extends TestBase
$m
=
\Upper_enum_value\NotAllowed
::
NULL
;
$m
=
\Upper_enum_value\NotAllowed
::
VOID
;
$m
=
\Upper_enum_value\NotAllowed
::
ITERABLE
;
$this
->
assertTrue
(
true
);
}
#########################################################
...
...
@@ -1297,6 +1305,7 @@ class GeneratedClassTest extends TestBase
{
$m
=
new
testLowerCaseMessage
();
$n
=
testLowerCaseEnum
::
VALUE
;
$this
->
assertTrue
(
true
);
}
#########################################################
...
...
@@ -1363,6 +1372,7 @@ class GeneratedClassTest extends TestBase
]);
TestUtil
::
assertTestMessage
(
$m
);
$this
->
assertTrue
(
true
);
}
#########################################################
...
...
php/tests/map_field_test.php
View file @
b0f6035f
...
...
@@ -7,7 +7,7 @@ use Google\Protobuf\Internal\MapField;
use
Foo\TestMessage
;
use
Foo\TestMessage\Sub
;
class
MapFieldTest
extends
PHPUnit_Framework_
TestCase
{
class
MapFieldTest
extends
\PHPUnit\Framework\
TestCase
{
#########################################################
# Test int32 field.
...
...
php/tests/test_base.php
View file @
b0f6035f
...
...
@@ -4,7 +4,7 @@ use Foo\TestMessage;
use
Foo\TestEnum
;
use
Foo\TestMessage\Sub
;
class
TestBase
extends
PHPUnit_Framework_
TestCase
class
TestBase
extends
\PHPUnit\Framework\
TestCase
{
public
function
setFields
(
TestMessage
$m
)
...
...
@@ -338,5 +338,6 @@ class TestBase extends PHPUnit_Framework_TestCase
// This test is to avoid the warning of no test by php unit.
public
function
testNone
()
{
$this
->
assertTrue
(
true
);
}
}
php/tests/well_known_test.php
View file @
b0f6035f
...
...
@@ -48,6 +48,7 @@ class WellKnownTest extends TestBase {
public
function
testImportDescriptorProto
()
{
$msg
=
new
TestImportDescriptorProto
();
$this
->
assertTrue
(
true
);
}
public
function
testAny
()
...
...
python/setup.py
View file @
b0f6035f
...
...
@@ -262,6 +262,9 @@ if __name__ == '__main__':
"Programming Language :: Python :: 3"
,
"Programming Language :: Python :: 3.3"
,
"Programming Language :: Python :: 3.4"
,
"Programming Language :: Python :: 3.5"
,
"Programming Language :: Python :: 3.6"
,
"Programming Language :: Python :: 3.7"
,
],
namespace_packages
=
[
'google'
],
packages
=
find_packages
(
...
...
src/google/protobuf/compiler/objectivec/objectivec_enum.cc
View file @
b0f6035f
...
...
@@ -35,6 +35,7 @@
#include <google/protobuf/compiler/objectivec/objectivec_helpers.h>
#include <google/protobuf/io/printer.h>
#include <google/protobuf/stubs/strutil.h>
#include <algorithm> // std::find()
namespace
google
{
namespace
protobuf
{
...
...
@@ -44,6 +45,17 @@ namespace objectivec {
EnumGenerator
::
EnumGenerator
(
const
EnumDescriptor
*
descriptor
)
:
descriptor_
(
descriptor
),
name_
(
EnumName
(
descriptor_
))
{
// Track the names for the enum values, and if an alias overlaps a base
// value, skip making a name for it. Likewise if two alias overlap, the
// first one wins.
// The one gap in this logic is if two base values overlap, but for that
// to happen you have to have "Foo" and "FOO" or "FOO_BAR" and "FooBar",
// and if an enum has that, it is already going to be confusing and a
// compile error is just fine.
// The values are still tracked to support the reflection apis and
// TextFormat handing since they are different there.
std
::
set
<
std
::
string
>
value_names
;
for
(
int
i
=
0
;
i
<
descriptor_
->
value_count
();
i
++
)
{
const
EnumValueDescriptor
*
value
=
descriptor_
->
value
(
i
);
const
EnumValueDescriptor
*
canonical_value
=
...
...
@@ -51,6 +63,14 @@ EnumGenerator::EnumGenerator(const EnumDescriptor* descriptor)
if
(
value
==
canonical_value
)
{
base_values_
.
push_back
(
value
);
value_names
.
insert
(
EnumValueName
(
value
));
}
else
{
string
value_name
(
EnumValueName
(
value
));
if
(
value_names
.
find
(
value_name
)
!=
value_names
.
end
())
{
alias_values_to_skip_
.
insert
(
value
);
}
else
{
value_names
.
insert
(
value_name
);
}
}
all_values_
.
push_back
(
value
);
}
...
...
@@ -90,6 +110,9 @@ void EnumGenerator::GenerateHeader(io::Printer* printer) {
"name"
,
name_
);
}
for
(
int
i
=
0
;
i
<
all_values_
.
size
();
i
++
)
{
if
(
alias_values_to_skip_
.
find
(
all_values_
[
i
])
!=
alias_values_to_skip_
.
end
())
{
continue
;
}
SourceLocation
location
;
if
(
all_values_
[
i
]
->
GetSourceLocation
(
&
location
))
{
string
comments
=
BuildCommentsString
(
location
,
true
).
c_str
();
...
...
src/google/protobuf/compiler/objectivec/objectivec_enum.h
View file @
b0f6035f
...
...
@@ -59,6 +59,7 @@ class EnumGenerator {
const
EnumDescriptor
*
descriptor_
;
std
::
vector
<
const
EnumValueDescriptor
*>
base_values_
;
std
::
vector
<
const
EnumValueDescriptor
*>
all_values_
;
std
::
set
<
const
EnumValueDescriptor
*>
alias_values_to_skip_
;
const
string
name_
;
};
...
...
tests.sh
View file @
b0f6035f
...
...
@@ -220,6 +220,38 @@ build_python() {
cd
..
}
build_python_version
()
{
internal_build_cpp
cd
python
envlist
=
$1
tox
-e
$envlist
cd
..
}
build_python27
()
{
build_python_version py27-python
}
build_python33
()
{
build_python_version py33-python
}
build_python34
()
{
build_python_version py34-python
}
build_python35
()
{
build_python_version py35-python
}
build_python36
()
{
build_python_version py36-python
}
build_python37
()
{
build_python_version py37-python
}
build_python_cpp
()
{
internal_build_cpp
export
LD_LIBRARY_PATH
=
../src/.libs
# for Linux
...
...
@@ -234,6 +266,40 @@ build_python_cpp() {
cd
..
}
build_python_cpp_version
()
{
internal_build_cpp
export
LD_LIBRARY_PATH
=
../src/.libs
# for Linux
export
DYLD_LIBRARY_PATH
=
../src/.libs
# for OS X
cd
python
envlist
=
$1
tox
-e
$envlist
cd
..
}
build_python27_cpp
()
{
build_python_cpp_version py27-cpp
}
build_python33_cpp
()
{
build_python_cpp_version py33-cpp
}
build_python34_cpp
()
{
build_python_cpp_version py34-cpp
}
build_python35_cpp
()
{
build_python_cpp_version py35-cpp
}
build_python36_cpp
()
{
build_python_cpp_version py36-cpp
}
build_python37_cpp
()
{
build_python_cpp_version py37-cpp
}
build_python_compatibility
()
{
internal_build_cpp
# Use the unit-tests extraced from 2.5.0 to test the compatibilty.
...
...
@@ -302,34 +368,25 @@ generate_php_test_proto() {
use_php
()
{
VERSION
=
$1
PHP
=
`
which php
`
PHP_CONFIG
=
`
which php-config
`
PHPIZE
=
`
which phpize
`
ln
-sfn
"/usr/local/php-
${
VERSION
}
/bin/php"
$PHP
ln
-sfn
"/usr/local/php-
${
VERSION
}
/bin/php-config"
$PHP_CONFIG
ln
-sfn
"/usr/local/php-
${
VERSION
}
/bin/phpize"
$PHPIZE
export
PATH
=
/usr/local/php-
${
VERSION
}
/bin:
$PATH
export
CPLUS_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
/include/php/main:/usr/local/php-
${
VERSION
}
/include/php/:
$CPLUS_INCLUDE_PATH
export
C_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
/include/php/main:/usr/local/php-
${
VERSION
}
/include/php/:
$C_INCLUDE_PATH
generate_php_test_proto
}
use_php_zts
()
{
VERSION
=
$1
PHP
=
`
which php
`
PHP_CONFIG
=
`
which php-config
`
PHPIZE
=
`
which phpize
`
ln
-sfn
"/usr/local/php-
${
VERSION
}
-zts/bin/php"
$PHP
ln
-sfn
"/usr/local/php-
${
VERSION
}
-zts/bin/php-config"
$PHP_CONFIG
ln
-sfn
"/usr/local/php-
${
VERSION
}
-zts/bin/phpize"
$PHPIZE
export
PATH
=
/usr/local/php-
${
VERSION
}
-zts
/bin:
$PATH
export
CPLUS_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
-zts
/include/php/main:/usr/local/php-
${
VERSION
}
-zts
/include/php/:
$CPLUS_INCLUDE_PATH
export
C_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
-zts
/include/php/main:/usr/local/php-
${
VERSION
}
-zts
/include/php/:
$C_INCLUDE_PATH
generate_php_test_proto
}
use_php_bc
()
{
VERSION
=
$1
PHP
=
`
which php
`
PHP_CONFIG
=
`
which php-config
`
PHPIZE
=
`
which phpize
`
ln
-sfn
"/usr/local/php-
${
VERSION
}
-bc/bin/php"
$PHP
ln
-sfn
"/usr/local/php-
${
VERSION
}
-bc/bin/php-config"
$PHP_CONFIG
ln
-sfn
"/usr/local/php-
${
VERSION
}
-bc/bin/phpize"
$PHPIZE
export
PATH
=
/usr/local/php-
${
VERSION
}
-bc
/bin:
$PATH
export
CPLUS_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
-bc
/include/php/main:/usr/local/php-
${
VERSION
}
-bc
/include/php/:
$CPLUS_INCLUDE_PATH
export
C_INCLUDE_PATH
=
/usr/local/php-
${
VERSION
}
-bc
/include/php/main:/usr/local/php-
${
VERSION
}
-bc
/include/php/:
$C_INCLUDE_PATH
generate_php_test_proto
}
...
...
@@ -338,9 +395,8 @@ build_php5.5() {
pushd
php
rm
-rf
vendor
cp
-r
/usr/local/vendor-5.5 vendor
wget https://phar.phpunit.de/phpunit-4.8.0.phar
-O
/usr/bin/phpunit
phpunit
composer update
./vendor/bin/phpunit
popd
pushd
conformance
make test_php
...
...
@@ -349,7 +405,6 @@ build_php5.5() {
build_php5.5_c
()
{
use_php 5.5
wget https://phar.phpunit.de/phpunit-4.8.0.phar
-O
/usr/bin/phpunit
pushd
php/tests
/bin/bash ./test.sh 5.5
popd
...
...
@@ -361,7 +416,6 @@ build_php5.5_c() {
build_php5.5_zts_c
()
{
use_php_zts 5.5
wget https://phar.phpunit.de/phpunit-4.8.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 5.5-zts
&&
cd
../..
# TODO(teboring): Add it back
# pushd conformance
...
...
@@ -373,9 +427,8 @@ build_php5.6() {
use_php 5.6
pushd
php
rm
-rf
vendor
cp
-r
/usr/local/vendor-5.6 vendor
wget https://phar.phpunit.de/phpunit-5.7.0.phar
-O
/usr/bin/phpunit
phpunit
composer update
./vendor/bin/phpunit
popd
pushd
conformance
make test_php
...
...
@@ -384,7 +437,6 @@ build_php5.6() {
build_php5.6_c
()
{
use_php 5.6
wget https://phar.phpunit.de/phpunit-5.7.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 5.6
&&
cd
../..
# TODO(teboring): Add it back
# pushd conformance
...
...
@@ -394,7 +446,6 @@ build_php5.6_c() {
build_php5.6_zts_c
()
{
use_php_zts 5.6
wget https://phar.phpunit.de/phpunit-5.7.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 5.6-zts
&&
cd
../..
# TODO(teboring): Add it back
# pushd conformance
...
...
@@ -431,9 +482,8 @@ build_php7.0() {
use_php 7.0
pushd
php
rm
-rf
vendor
cp
-r
/usr/local/vendor-7.0 vendor
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
phpunit
composer update
./vendor/bin/phpunit
popd
pushd
conformance
make test_php
...
...
@@ -442,7 +492,6 @@ build_php7.0() {
build_php7.0_c
()
{
use_php 7.0
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 7.0
&&
cd
../..
# TODO(teboring): Add it back
# pushd conformance
...
...
@@ -452,7 +501,6 @@ build_php7.0_c() {
build_php7.0_zts_c
()
{
use_php_zts 7.0
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 7.0-zts
&&
cd
../..
# TODO(teboring): Add it back.
# pushd conformance
...
...
@@ -494,9 +542,8 @@ build_php7.1() {
use_php 7.1
pushd
php
rm
-rf
vendor
cp
-r
/usr/local/vendor-7.1 vendor
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
phpunit
composer update
./vendor/bin/phpunit
popd
pushd
conformance
make test_php
...
...
@@ -506,7 +553,6 @@ build_php7.1() {
build_php7.1_c
()
{
ENABLE_CONFORMANCE_TEST
=
$1
use_php 7.1
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 7.1
&&
cd
../..
if
[
"
$ENABLE_CONFORMANCE_TEST
"
=
"true"
]
then
...
...
@@ -518,7 +564,6 @@ build_php7.1_c() {
build_php7.1_zts_c
()
{
use_php_zts 7.1
wget https://phar.phpunit.de/phpunit-5.6.0.phar
-O
/usr/bin/phpunit
cd
php/tests
&&
/bin/bash ./test.sh 7.1-zts
&&
cd
../..
pushd
conformance
# make test_php_c
...
...
@@ -545,6 +590,11 @@ build_php_all() {
build_php_compatibility
}
build_benchmark
()
{
use_php 7.1
cd
kokoro/linux/benchmark
&&
./run.sh
}
# -------- main --------
if
[
"$#"
-ne
1
]
;
then
...
...
@@ -577,7 +627,8 @@ Usage: $0 { cpp |
php_compatibility |
php7.1 |
php7.1_c |
php_all)
php_all |
benchmark)
"
exit
1
fi
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment