|  | #!/bin/bash | 
|  |  | 
|  | function run_test() { | 
|  | # Generate test proto files. | 
|  | $1 -Iprotos/src -I../../../src/ --csharp_out=src/Google.Protobuf.Test \ | 
|  | --csharp_opt=base_namespace=Google.Protobuf \ | 
|  | protos/src/google/protobuf/unittest_import_proto3.proto \ | 
|  | protos/src/google/protobuf/unittest_import_public_proto3.proto \ | 
|  | protos/src/google/protobuf/unittest_well_known_types.proto | 
|  |  | 
|  | $1 -Iprotos/csharp --csharp_out=src/Google.Protobuf.Test \ | 
|  | --csharp_opt=base_namespace=UnitTest.Issues \ | 
|  | protos/csharp/protos/unittest_issues.proto | 
|  |  | 
|  | $2 -Iprotos/src --csharp_out=src/Google.Protobuf.Test \ | 
|  | --csharp_opt=base_namespace=Google.Protobuf \ | 
|  | protos/src/google/protobuf/unittest_proto3.proto \ | 
|  | protos/src/google/protobuf/map_unittest_proto3.proto | 
|  |  | 
|  | # Build and test. | 
|  | dotnet restore src/Google.Protobuf/Google.Protobuf.csproj | 
|  | dotnet restore src/Google.Protobuf.Test/Google.Protobuf.Test.csproj | 
|  | dotnet build -c Release src/Google.Protobuf/Google.Protobuf.csproj | 
|  | dotnet build -c Release src/Google.Protobuf.Test/Google.Protobuf.Test.csproj | 
|  | dotnet run -c Release -f netcoreapp2.1 -p src/Google.Protobuf.Test/Google.Protobuf.Test.csproj | 
|  | } | 
|  |  | 
|  | set -ex | 
|  |  | 
|  | # Change to the script's directory. | 
|  | cd $(dirname $0) | 
|  |  | 
|  | # Version of the tests (i.e., the version of protobuf from where we extracted | 
|  | # these tests). | 
|  | TEST_VERSION=3.0.0 | 
|  |  | 
|  | # The old version of protobuf that we are testing compatibility against. This | 
|  | # is usually the same as TEST_VERSION (i.e., we use the tests extracted from | 
|  | # that version to test compatibility of the newest runtime against it), but it | 
|  | # is also possible to use this same test set to test the compatibility of the | 
|  | # latest version against other versions. | 
|  | OLD_VERSION=$1 | 
|  | OLD_VERSION_PROTOC=https://repo1.maven.org/maven2/com/google/protobuf/protoc/$OLD_VERSION/protoc-$OLD_VERSION-linux-x86_64.exe | 
|  |  | 
|  | echo "Running compatibility tests with $OLD_VERSION" | 
|  |  | 
|  | # Check protoc | 
|  | [ -f ../../../src/protoc ] || { | 
|  | echo "[ERROR]: Please build protoc first." | 
|  | exit 1 | 
|  | } | 
|  |  | 
|  | # Download old version protoc compiler (for linux). | 
|  | wget $OLD_VERSION_PROTOC -O old_protoc | 
|  | chmod +x old_protoc | 
|  |  | 
|  | # Test source compatibility. In these tests we recompile everything against | 
|  | # the new runtime (including old version generated code). | 
|  | # Copy the new runtime and keys. | 
|  | cp ../../src/Google.Protobuf src/Google.Protobuf -r | 
|  | cp ../../keys . -r | 
|  |  | 
|  | # Test A.1: | 
|  | #   proto set 1: use old version | 
|  | #   proto set 2 which may import protos in set 1: use old version | 
|  | run_test "./old_protoc" "./old_protoc" | 
|  |  | 
|  | # Test A.2: | 
|  | #   proto set 1: use new version | 
|  | #   proto set 2 which may import protos in set 1: use old version | 
|  | run_test "../../../src/protoc" "./old_protoc" | 
|  |  | 
|  | # Test A.3: | 
|  | #   proto set 1: use old version | 
|  | #   proto set 2 which may import protos in set 1: use new version | 
|  | run_test "./old_protoc" "../../../src/protoc" | 
|  |  | 
|  | rm old_protoc | 
|  | rm keys -r | 
|  | rm src/Google.Protobuf -r |