Karthik Ravi Shankar f1bc43edf6 Revert "Move create_channel and credentials from ::grpc_impl to ::grpc" 5 gadi atpakaļ
..
client 9404f66f70 Replace most uses of gpr_asprintf() with absl calls. 5 gadi atpakaļ
cocoapods 165ee5007a Replaced grpc::string with std::string 5 gadi atpakaļ
codegen c86cfc305c Remove all std::mem_fn and std::bind from service definitions and setup 5 gadi atpakaļ
common 165ee5007a Replaced grpc::string with std::string 5 gadi atpakaļ
end2end 181781387d xDS v3 support 5 gadi atpakaļ
ext 2e958cf01b (Census client filter: use current span and tags. original_author=g-easy) 5 gadi atpakaļ
grpclb 62ac3f075a Added call to grpc::testing::TestEnvironment in tests 5 gadi atpakaļ
interop e681f37054 Remove env var protection of new xds routing code. 5 gadi atpakaļ
ios 165ee5007a Replaced grpc::string with std::string 5 gadi atpakaļ
microbenchmarks 9d79ca6058 C++ify core server 5 gadi atpakaļ
naming 9404f66f70 Replace most uses of gpr_asprintf() with absl calls. 5 gadi atpakaļ
performance 9d79ca6058 C++ify core server 5 gadi atpakaļ
qps 165ee5007a Replaced grpc::string with std::string 5 gadi atpakaļ
server c736cf073c Added call to grpc::testing::TestEnvironment in more tests 5 gadi atpakaļ
test 165ee5007a Replaced grpc::string with std::string 5 gadi atpakaļ
thread_manager c34bef4ca4 Format all Bazel files with buildifier 6 gadi atpakaļ
util f57879ac56 Flag protect new logs 5 gadi atpakaļ
README-iOS.md b436758b14 Added documentation for C++ tests on iOS 6 gadi atpakaļ

README-iOS.md

C++ tests on iOS

GTMGoogleTestRunner is used to convert googletest cases to XCTest that can be run on iOS. GTMGoogleTestRunner doesn't execute the main function, so we can't have any test logic in main. However, it's ok to call ::testing::InitGoogleTest in main, as GTMGoogleTestRunner calls InitGoogleTest. grpc::testing::TestEnvironment can also be called from main, as it does some test initialization (install crash handler, seed RNG) that's not strictly required to run testcases on iOS.

Porting exising C++ tests to run on iOS

Please follow these guidelines when porting tests to run on iOS:

  • Tests need to use the googletest framework
  • Any setup/teardown code in main needs to be moved to SetUpTestCase/TearDownTestCase, and TEST needs to be changed to TEST_F.
  • Death tests are not supported on iOS, so use the *_IF_SUPPORTED() macros to ensure that your code compiles on iOS.

For example, the following test

TEST(MyTest, TestOne) {
  ASSERT_DEATH(ThisShouldDie(), "");
}

int main(int argc, char** argv) {
  grpc::testing::TestEnvironment env(argc, argv);
  ::testing::InitGoogleTest(&argc, argv);
  grpc_init();
  return RUN_ALL_TESTS();
  grpc_shutdown();
}

should be changed to

class MyTest : public ::testing::Test {
 protected:
  static void SetUpTestCase() { grpc_init(); }
  static void TearDownTestCase() { grpc_shutdown(); }
};

TEST_F(MyTest, TestOne) {
  ASSERT_DEATH_IF_SUPPORTED(ThisShouldDie(), "");
}

int main(int argc, char** argv) {
  grpc::testing::TestEnvironment env(argc, argv);
  ::testing::InitGoogleTest(&argc, argv);
  return RUN_ALL_TESTS();
}

Limitations

Due to a limitation in GTMGoogleTestRunner, SetUpTestCase/TeardownTestCase will be called before/after every individual test case, similar to SetUp/TearDown.