gvisor/test
Ghanan Gowripalan 34ec00c5e7 Run raw IP socket syscall tests on Fuchsia
+ Do not check for CAP_NET_RAW on Fuchsia

  Fuchsia does not support capabilities the same way Linux does. Instead
  emulate the check for CAP_NET_RAW by checking if a raw IP sockets may
  be created.

PiperOrigin-RevId: 389663218
2021-08-09 10:20:21 -07:00
..
benchmarks [benchmarks] Fix redis benchmark. 2021-06-11 11:56:15 -07:00
cmd/test_app Rename go files that contain "main" function to main.go. 2021-06-09 17:36:51 -07:00
e2e Support RTM_DELLINK 2021-07-30 15:41:36 -07:00
fsstress Add fsstress test to goferfs 2021-07-20 22:21:24 -07:00
fuse Disable all tests dependent on cloud_gvisor::testing::FuseTest. 2021-06-10 15:54:34 -07:00
image Fail tests when container returns non-zero status 2021-04-05 11:39:53 -07:00
iptables iptables: support postrouting hook and SNAT target 2021-04-09 21:11:26 -07:00
kubernetes
packetdrill Clean test tags. 2021-04-20 13:11:25 -07:00
packetimpact Add go:build directives as required by Go 1.17's gofmt. 2021-07-20 16:28:45 -07:00
perf Add verity_randread benchmark test 2021-08-04 17:18:02 -07:00
root Merge pull request #6292 from btw616:local-timezone 2021-07-26 16:47:13 -07:00
runner Add verity open benchmark test 2021-07-23 14:35:42 -07:00
runtimes Replace whitelist with allowlist 2021-07-13 17:20:41 -07:00
syscalls Run raw IP socket syscall tests on Fuchsia 2021-08-09 10:20:21 -07:00
uds [op] Replace syscall package usage with golang.org/x/sys/unix in test/. 2021-03-06 09:54:09 -08:00
util Run raw IP socket syscall tests on Fuchsia 2021-08-09 10:20:21 -07:00
BUILD Standardize on tools directory. 2020-01-27 12:21:00 -08:00
README.md

README.md

Tests

The tests defined under this path are verifying functionality beyond what unit tests can cover, e.g. integration and end to end tests. Due to their nature, they may need extra setup in the test machine and extra configuration to run.

  • syscalls: system call tests use a local runner, and do not require additional configuration in the machine.
  • integration: defines integration tests that uses docker run to test functionality.
  • image: basic end to end test for popular images. These require the same setup as integration tests.
  • root: tests that require to be run as root. These require the same setup as integration tests.
  • util: utilities library to support the tests.

For the above noted cases, the relevant runtime must be installed via runsc install before running. Just note that they require specific configuration to work. This is handled automatically by the test scripts in the scripts directory and they can be used to run tests locally on your machine. They are also used to run these tests in kokoro.

Example:

To run image and integration tests, run:

make docker-tests

To run root tests, run:

make root-tests

There are a few other interesting variations for image and integration tests:

  • overlay: sets writable overlay inside the sentry
  • hostnet: configures host network pass-thru, instead of netstack
  • kvm: runsc the test using the KVM platform, instead of ptrace

The test will build runsc, configure it with your local docker, restart dockerd, and run tests. The location for runsc logs is printed to the output.