| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | package request | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2018-01-24 14:28:26 +01:00
										 |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-14 09:36:06 +01:00
										 |  |  | 	"github.com/coredns/coredns/plugin/test" | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/miekg/dns" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestRequestDo(t *testing.T) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	st.Do() | 
					
						
							| 
									
										
										
										
											2019-10-04 09:44:58 +01:00
										 |  |  | 	if !st.do { | 
					
						
							| 
									
										
										
										
											2018-07-03 09:47:26 +01:00
										 |  |  | 		t.Errorf("Expected st.do to be set") | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestRequestRemote(t *testing.T) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 	if st.IP() != "10.240.0.1" { | 
					
						
							| 
									
										
										
										
											2018-07-03 09:47:26 +01:00
										 |  |  | 		t.Errorf("Wrong IP from request") | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	p := st.Port() | 
					
						
							|  |  |  | 	if p == "" { | 
					
						
							| 
									
										
										
										
											2018-07-03 09:47:26 +01:00
										 |  |  | 		t.Errorf("Failed to get Port from request") | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if p != "40212" { | 
					
						
							| 
									
										
										
										
											2018-07-03 09:47:26 +01:00
										 |  |  | 		t.Errorf("Wrong port from request") | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-31 16:24:11 +02:00
										 |  |  | func TestRequestMalformed(t *testing.T) { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	st := Request{Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.QType(); x != 0 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 0 Qtype, got %d", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.QClass(); x != 0 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 0 QClass, got %d", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.QName(); x != "." { | 
					
						
							|  |  |  | 		t.Errorf("Expected . Qname, got %s", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.Name(); x != "." { | 
					
						
							|  |  |  | 		t.Errorf("Expected . Name, got %s", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.Type(); x != "" { | 
					
						
							|  |  |  | 		t.Errorf("Expected empty Type, got %s", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if x := st.Class(); x != "" { | 
					
						
							|  |  |  | 		t.Errorf("Expected empty Class, got %s", x) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | func TestRequestScrubAnswer(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2018-01-24 14:28:26 +01:00
										 |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("large.example.com.", dns.TypeSRV) | 
					
						
							|  |  |  | 	req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(m) | 
					
						
							|  |  |  | 	for i := 1; i < 200; i++ { | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 		reply.Answer = append(reply.Answer, test.SRV( | 
					
						
							|  |  |  | 			fmt.Sprintf("large.example.com. 10 IN SRV 0 0 80 10-0-0-%d.default.pod.k8s.example.com.", i))) | 
					
						
							| 
									
										
										
										
											2018-01-24 14:28:26 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 17:55:40 +01:00
										 |  |  | 	req.Scrub(reply) | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 	if want, got := req.Size(), reply.Len(); want < got { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							| 
									
										
										
										
											2018-01-24 14:28:26 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 	if !reply.Truncated { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Want scrub to set truncated bit") | 
					
						
							| 
									
										
										
										
											2018-01-24 14:28:26 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | func TestRequestScrubExtra(t *testing.T) { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("large.example.com.", dns.TypeSRV) | 
					
						
							|  |  |  | 	req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(m) | 
					
						
							|  |  |  | 	for i := 1; i < 200; i++ { | 
					
						
							|  |  |  | 		reply.Extra = append(reply.Extra, test.SRV( | 
					
						
							|  |  |  | 			fmt.Sprintf("large.example.com. 10 IN SRV 0 0 80 10-0-0-%d.default.pod.k8s.example.com.", i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 17:55:40 +01:00
										 |  |  | 	req.Scrub(reply) | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 	if want, got := req.Size(), reply.Len(); want < got { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-07-12 12:33:27 +00:00
										 |  |  | 	if !reply.Truncated { | 
					
						
							|  |  |  | 		t.Errorf("Want scrub to set truncated bit") | 
					
						
							| 
									
										
										
										
											2018-02-21 21:13:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | func TestRequestScrubExtraEdns0(t *testing.T) { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("large.example.com.", dns.TypeSRV) | 
					
						
							|  |  |  | 	m.SetEdns0(4096, true) | 
					
						
							|  |  |  | 	req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(m) | 
					
						
							|  |  |  | 	for i := 1; i < 200; i++ { | 
					
						
							|  |  |  | 		reply.Extra = append(reply.Extra, test.SRV( | 
					
						
							|  |  |  | 			fmt.Sprintf("large.example.com. 10 IN SRV 0 0 80 10-0-0-%d.default.pod.k8s.example.com.", i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 17:55:40 +01:00
										 |  |  | 	req.Scrub(reply) | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | 	if want, got := req.Size(), reply.Len(); want < got { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-07-12 12:33:27 +00:00
										 |  |  | 	if !reply.Truncated { | 
					
						
							|  |  |  | 		t.Errorf("Want scrub to set truncated bit") | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-28 10:27:38 +01:00
										 |  |  | func TestRequestScrubExtraRegression(t *testing.T) { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("large.example.com.", dns.TypeSRV) | 
					
						
							|  |  |  | 	m.SetEdns0(2048, true) | 
					
						
							|  |  |  | 	req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(m) | 
					
						
							|  |  |  | 	for i := 1; i < 33; i++ { | 
					
						
							|  |  |  | 		reply.Answer = append(reply.Answer, test.SRV( | 
					
						
							|  |  |  | 			fmt.Sprintf("large.example.com. 10 IN SRV 0 0 80 10-0-0-%d.default.pod.k8s.example.com.", i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for i := 1; i < 33; i++ { | 
					
						
							|  |  |  | 		reply.Extra = append(reply.Extra, test.A( | 
					
						
							|  |  |  | 			fmt.Sprintf("10-0-0-%d.default.pod.k8s.example.com. 10 IN A 10.0.0.%d", i, i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 17:55:40 +01:00
										 |  |  | 	reply = req.Scrub(reply) | 
					
						
							| 
									
										
										
										
											2018-07-28 10:27:38 +01:00
										 |  |  | 	if want, got := req.Size(), reply.Len(); want < got { | 
					
						
							|  |  |  | 		t.Errorf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-07-12 12:33:27 +00:00
										 |  |  | 	if !reply.Truncated { | 
					
						
							|  |  |  | 		t.Errorf("Want scrub to set truncated bit") | 
					
						
							| 
									
										
										
										
											2018-07-28 10:27:38 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-03 11:01:56 +01:00
										 |  |  | func TestTruncation(t *testing.T) { | 
					
						
							|  |  |  | 	for bufsize := 1024; bufsize <= 4096; bufsize += 12 { | 
					
						
							|  |  |  | 		m := new(dns.Msg) | 
					
						
							|  |  |  | 		m.SetQuestion("http.service.tcp.srv.k8s.example.org", dns.TypeSRV) | 
					
						
							|  |  |  | 		m.SetEdns0(uint16(bufsize), true) | 
					
						
							|  |  |  | 		req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		reply := new(dns.Msg) | 
					
						
							|  |  |  | 		reply.SetReply(m) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for i := 0; i < 61; i++ { | 
					
						
							|  |  |  | 			reply.Answer = append(reply.Answer, test.SRV(fmt.Sprintf("http.service.tcp.srv.k8s.example.org. 5 IN SRV 0 0 80 10-144-230-%d.default.pod.k8s.example.org.", i))) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for i := 0; i < 5; i++ { | 
					
						
							|  |  |  | 			reply.Extra = append(reply.Extra, test.A(fmt.Sprintf("ip-10-10-52-5%d.subdomain.example.org. 5 IN A 10.10.52.5%d", i, i))) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for i := 0; i < 5; i++ { | 
					
						
							|  |  |  | 			reply.Ns = append(reply.Ns, test.NS(fmt.Sprintf("srv.subdomain.example.org. 5 IN NS ip-10-10-33-6%d.subdomain.example.org.", i))) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		req.Scrub(reply) | 
					
						
							|  |  |  | 		want, got := req.Size(), reply.Len() | 
					
						
							|  |  |  | 		if want < got { | 
					
						
							|  |  |  | 			t.Fatalf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | func TestRequestScrubAnswerExact(t *testing.T) { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("large.example.com.", dns.TypeSRV) | 
					
						
							|  |  |  | 	m.SetEdns0(867, false) // Bit fiddly, but this hits the rl == size break clause in Scrub, 52 RRs should remain. | 
					
						
							|  |  |  | 	req := Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(m) | 
					
						
							|  |  |  | 	for i := 1; i < 200; i++ { | 
					
						
							|  |  |  | 		reply.Answer = append(reply.Answer, test.A(fmt.Sprintf("large.example.com. 10 IN A 127.0.0.%d", i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 17:55:40 +01:00
										 |  |  | 	req.Scrub(reply) | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | 	if want, got := req.Size(), reply.Len(); want < got { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Want scrub to reduce message length below %d bytes, got %d bytes", want, got) | 
					
						
							| 
									
										
										
										
											2018-03-24 11:50:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-15 08:42:49 +00:00
										 |  |  | func TestRequestMatch(t *testing.T) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							| 
									
										
										
										
											2018-05-09 12:35:42 +01:00
										 |  |  | 	reply.Response = true | 
					
						
							| 
									
										
										
										
											2018-03-15 08:42:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	reply.SetQuestion("example.com.", dns.TypeMX) | 
					
						
							|  |  |  | 	if b := st.Match(reply); b { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Failed to match %s %d, got %t, expected %t", "example.com.", dns.TypeMX, b, false) | 
					
						
							| 
									
										
										
										
											2018-03-15 08:42:49 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply.SetQuestion("example.com.", dns.TypeA) | 
					
						
							|  |  |  | 	if b := st.Match(reply); !b { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Failed to match %s %d, got %t, expected %t", "example.com.", dns.TypeA, b, true) | 
					
						
							| 
									
										
										
										
											2018-03-15 08:42:49 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply.SetQuestion("example.org.", dns.TypeA) | 
					
						
							|  |  |  | 	if b := st.Match(reply); b { | 
					
						
							| 
									
										
										
										
											2018-06-02 20:28:56 +01:00
										 |  |  | 		t.Errorf("Failed to match %s %d, got %t, expected %t", "example.org.", dns.TypeA, b, false) | 
					
						
							| 
									
										
										
										
											2018-03-15 08:42:49 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | func BenchmarkRequestDo(b *testing.B) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i := 0; i < b.N; i++ { | 
					
						
							|  |  |  | 		st.Do() | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func BenchmarkRequestSize(b *testing.B) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i := 0; i < b.N; i++ { | 
					
						
							|  |  |  | 		st.Size() | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-28 10:27:38 +01:00
										 |  |  | func BenchmarkRequestScrub(b *testing.B) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	reply := new(dns.Msg) | 
					
						
							|  |  |  | 	reply.SetReply(st.Req) | 
					
						
							|  |  |  | 	for i := 1; i < 33; i++ { | 
					
						
							|  |  |  | 		reply.Answer = append(reply.Answer, test.SRV( | 
					
						
							|  |  |  | 			fmt.Sprintf("large.example.com. 10 IN SRV 0 0 80 10-0-0-%d.default.pod.k8s.example.com.", i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for i := 1; i < 33; i++ { | 
					
						
							|  |  |  | 		reply.Extra = append(reply.Extra, test.A( | 
					
						
							|  |  |  | 			fmt.Sprintf("10-0-0-%d.default.pod.k8s.example.com. 10 IN A 10.0.0.%d", i, i))) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	b.ResetTimer() | 
					
						
							|  |  |  | 	for i := 0; i < b.N; i++ { | 
					
						
							|  |  |  | 		st.Scrub(reply.Copy()) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | func testRequest() Request { | 
					
						
							|  |  |  | 	m := new(dns.Msg) | 
					
						
							|  |  |  | 	m.SetQuestion("example.com.", dns.TypeA) | 
					
						
							| 
									
										
										
										
											2018-07-28 10:27:38 +01:00
										 |  |  | 	m.SetEdns0(4096, true) | 
					
						
							| 
									
										
										
										
											2016-09-07 11:10:16 +01:00
										 |  |  | 	return Request{W: &test.ResponseWriter{}, Req: m} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-07-03 09:47:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | func TestRequestClear(t *testing.T) { | 
					
						
							|  |  |  | 	st := testRequest() | 
					
						
							|  |  |  | 	if st.IP() != "10.240.0.1" { | 
					
						
							|  |  |  | 		t.Errorf("Wrong IP from request") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	p := st.Port() | 
					
						
							|  |  |  | 	if p == "" { | 
					
						
							|  |  |  | 		t.Errorf("Failed to get Port from request") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	st.Clear() | 
					
						
							|  |  |  | 	if st.ip != "" { | 
					
						
							|  |  |  | 		t.Errorf("Expected st.ip to be cleared after Clear") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if st.port != "" { | 
					
						
							|  |  |  | 		t.Errorf("Expected st.port to be cleared after Clear") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |