1#!/bin/bash -eu 2# 3# Copyright 2014 Google Inc. All rights reserved. 4# 5# Licensed under the Apache License, Version 2.0 (the "License"); 6# you may not use this file except in compliance with the License. 7# You may obtain a copy of the License at 8# 9# http://www.apache.org/licenses/LICENSE-2.0 10# 11# Unless required by applicable law or agreed to in writing, software 12# distributed under the License is distributed on an "AS IS" BASIS, 13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14# See the License for the specific language governing permissions and 15# limitations under the License. 16 17pushd "$(dirname $0)" >/dev/null 18test_dir="$(pwd)" 19go_path=${test_dir}/go_gen 20go_src=${go_path}/src 21 22# Emit Go code for the example schemas in the test dir: 23../flatc -g --gen-object-api -I include_test monster_test.fbs optional_scalars.fbs 24 25# Go requires a particular layout of files in order to link multiple packages. 26# Copy flatbuffer Go files to their own package directories to compile the 27# test binary: 28mkdir -p ${go_src}/MyGame/Example 29mkdir -p ${go_src}/MyGame/Example2 30mkdir -p ${go_src}/github.com/google/flatbuffers/go 31mkdir -p ${go_src}/flatbuffers_test 32mkdir -p ${go_src}/optional_scalars 33 34cp -a MyGame/*.go ./go_gen/src/MyGame/ 35cp -a MyGame/Example/*.go ./go_gen/src/MyGame/Example/ 36cp -a MyGame/Example2/*.go ./go_gen/src/MyGame/Example2/ 37# do not compile the gRPC generated files, which are not tested by go_test.go 38# below, but have their own test. 39rm ./go_gen/src/MyGame/Example/*_grpc.go 40cp -a ../go/* ./go_gen/src/github.com/google/flatbuffers/go 41cp -a ./go_test.go ./go_gen/src/flatbuffers_test/ 42cp -a optional_scalars/*.go ./go_gen/src/optional_scalars 43 44# https://stackoverflow.com/a/63545857/7024978 45# We need to turn off go modules for this script 46# to work. 47go env -w GO111MODULE=off 48 49# Run tests with necessary flags. 50# Developers may wish to see more detail by appending the verbosity flag 51# -test.v to arguments for this command, as in: 52# go -test -test.v ... 53# Developers may also wish to run benchmarks, which may be achieved with the 54# flag -test.bench and the wildcard regexp ".": 55# go -test -test.bench=. ... 56GOPATH=${go_path} go test flatbuffers_test \ 57 --coverpkg=github.com/google/flatbuffers/go \ 58 --cpp_data=${test_dir}/monsterdata_test.mon \ 59 --out_data=${test_dir}/monsterdata_go_wire.mon \ 60 --bench=. \ 61 --benchtime=3s \ 62 --fuzz=true \ 63 --fuzz_fields=4 \ 64 --fuzz_objects=10000 65 66GO_TEST_RESULT=$? 67rm -rf ${go_path}/{pkg,src} 68if [[ $GO_TEST_RESULT == 0 ]]; then 69 echo "OK: Go tests passed." 70else 71 echo "KO: Go tests failed." 72 exit 1 73fi 74 75NOT_FMT_FILES=$(gofmt -l MyGame) 76if [[ ${NOT_FMT_FILES} != "" ]]; then 77 echo "These files are not well gofmt'ed:" 78 echo 79 echo "${NOT_FMT_FILES}" 80 # enable this when enums are properly formated 81 # exit 1 82fi 83