netns_test.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package netns
  2. import (
  3. "runtime"
  4. "sync"
  5. "testing"
  6. )
  7. func TestGetNewSetDelete(t *testing.T) {
  8. runtime.LockOSThread()
  9. defer runtime.UnlockOSThread()
  10. origns, err := Get()
  11. if err != nil {
  12. t.Fatal(err)
  13. }
  14. newns, err := New()
  15. if err != nil {
  16. t.Fatal(err)
  17. }
  18. if origns.Equal(newns) {
  19. t.Fatal("New ns failed")
  20. }
  21. if err := Set(origns); err != nil {
  22. t.Fatal(err)
  23. }
  24. newns.Close()
  25. if newns.IsOpen() {
  26. t.Fatal("newns still open after close", newns)
  27. }
  28. ns, err := Get()
  29. if err != nil {
  30. t.Fatal(err)
  31. }
  32. if !ns.Equal(origns) {
  33. t.Fatal("Reset ns failed", origns, newns, ns)
  34. }
  35. }
  36. func TestNone(t *testing.T) {
  37. ns := None()
  38. if ns.IsOpen() {
  39. t.Fatal("None ns is open", ns)
  40. }
  41. }
  42. func TestThreaded(t *testing.T) {
  43. ncpu := runtime.GOMAXPROCS(-1)
  44. if ncpu < 2 {
  45. t.Skip("-cpu=2 or larger required")
  46. }
  47. // Lock this thread simply to ensure other threads get used.
  48. runtime.LockOSThread()
  49. defer runtime.UnlockOSThread()
  50. wg := &sync.WaitGroup{}
  51. for i := 0; i < ncpu; i++ {
  52. wg.Add(1)
  53. go func() {
  54. defer wg.Done()
  55. TestGetNewSetDelete(t)
  56. }()
  57. }
  58. wg.Wait()
  59. }