package request import ( "fmt" "testing" "github.com/coredns/coredns/plugin/test" "github.com/miekg/dns" ) func TestRequestDo(t *testing.T) { st := testRequest() st.Do() if st.do == nil { t.Errorf("Expected st.do to be set") } } func TestRequestRemote(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") } if p != "40212" { t.Errorf("Wrong port from request") } } 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) } } func TestRequestScrubAnswer(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.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))) } req.Scrub(reply) 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) } if !reply.Truncated { t.Errorf("Want scrub to set truncated bit") } } 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))) } req.Scrub(reply) 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) } if reply.Truncated { t.Errorf("Want scrub to not set truncated bit") } } 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))) } req.Scrub(reply) 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) } if reply.Truncated { t.Errorf("Want scrub to not set truncated bit") } } 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))) } reply = req.Scrub(reply) 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) } if reply.Truncated { t.Errorf("Want scrub to not set truncated bit") } } 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) } } } 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))) } req.Scrub(reply) 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) } } func TestRequestMatch(t *testing.T) { st := testRequest() reply := new(dns.Msg) reply.Response = true reply.SetQuestion("example.com.", dns.TypeMX) if b := st.Match(reply); b { t.Errorf("Failed to match %s %d, got %t, expected %t", "example.com.", dns.TypeMX, b, false) } reply.SetQuestion("example.com.", dns.TypeA) if b := st.Match(reply); !b { t.Errorf("Failed to match %s %d, got %t, expected %t", "example.com.", dns.TypeA, b, true) } reply.SetQuestion("example.org.", dns.TypeA) if b := st.Match(reply); b { t.Errorf("Failed to match %s %d, got %t, expected %t", "example.org.", dns.TypeA, b, false) } } 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() } } 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()) } } func testRequest() Request { m := new(dns.Msg) m.SetQuestion("example.com.", dns.TypeA) m.SetEdns0(4096, true) return Request{W: &test.ResponseWriter{}, Req: m} } 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") } } api-context Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/examples/with-vitest (unfollow)
AgeCommit message (Expand)AuthorFilesLines
2022-09-30[@astrojs/image] fixes a bug in dev when <Image /> is used with no transforma...Gravatar Tony Sullivan 5-6/+30
2022-09-30Update seven-shrimps-hope.md (#4934)Gravatar Tony Sullivan 1-1/+1
2022-09-30[ci] update lockfile (#4927)Gravatar Fred K. Bot 1-280/+280
2022-09-30Move module declarations for Markdown and MDX so they're available everywhere...Gravatar Erika 4-35/+46
2022-09-29[ci] formatGravatar tony-sull 4-17/+29
2022-09-29[@astrojs/image] adding caching support for SSG builds (#4909)Gravatar Tony Sullivan 8-10/+240
2022-09-29[ci] release (#4903)astro@1.4.0@astrojs/vue@1.1.0@astrojs/vercel@2.1.0@astrojs/telemetry@1.0.1@astrojs/tailwind@2.0.2@astrojs/svelte@1.0.1@astrojs/rss@1.0.2@astrojs/preact@1.1.1@astrojs/node@1.1.0@astrojs/netlify@1.1.0@astrojs/mdx@0.11.3@astrojs/markdown-remark@1.1.3@astrojs/image@0.8.1@astrojs/deno@1.1.0@astrojs/cloudflare@2.1.0Gravatar Fred K. Bot 65-235/+512
2022-09-29[ci] update lockfile (#4899)Gravatar Fred K. Bot 1-735/+718
2022-09-29[ci] formatGravatar matthewp 1-1/+3
2022-09-29fix trailing slash mismatch in dev vs build in docs example (#4912)Gravatar Rishi Raj Jain 1-1/+1
2022-09-29[ci] formatGravatar bluwy 1-1/+1
2022-09-29Support Vue JSX (#4897)Gravatar Bjorn Lu 12-5/+329
2022-09-28[ci] formatGravatar matthewp 1-8/+4
2022-09-28Fix CSS ordering between imported and Astro styles (#4907)Gravatar Matthew Phillips 12-7/+218
2022-09-28[ci] formatGravatar matthewp 23-137/+127
2022-09-28Astro.cookies implementation (#4876)Gravatar Matthew Phillips 32-29/+943
2022-09-28Fix: let Squoosh default image quality internally (#4906)Gravatar Tony Sullivan 5-11/+20
2022-09-28Update README.md (#4898)Gravatar stijlmassi 1-2/+3
2022-09-28Fix test (#4904)Gravatar Bjorn Lu 2-1/+7
2022-09-28[ci] formatGravatar FredKSchott 2-4/+4
2022-09-28redesign basics template (#4879)Gravatar Fred K. Schott 3-88/+34
2022-09-28[ci] formatGravatar bluwy 1-2/+2
2022-09-28Remove shamefully-hoist (#4842)Gravatar Bjorn Lu 104-527/+768
2022-09-28[ci] formatGravatar matthewp 4-14/+16
2022-09-28Hoist hydration script out of slot templates (#4891)Gravatar Matthew Phillips 13-43/+165
2022-09-28Ensure head content rendered once with lazy layouts (#4892)Gravatar Matthew Phillips 9-3/+59
2022-09-27fixed typing (#4893)Gravatar tweenietomatoes 1-1/+1
2022-09-27[ci] release (#4846)create-astro@1.1.0astro@1.3.1@astrojs/webapi@1.1.0@astrojs/vercel@2.0.1@astrojs/mdx@0.11.2@astrojs/image@0.8.0Gravatar Fred K. Bot 60-185/+169
2022-09-27fix: post API routes in SSG should warn or error during dev mode (#4878)Gravatar Rishi Raj Jain 3-2/+17
2022-09-27docs: Fix links to Tailwind examples (#4883)Gravatar Deanmv 1-1/+1
2022-09-27Set SSR target webworker for Vercel edge (#4884)Gravatar Bjorn Lu 2-0/+6
2022-09-27[ci] update lockfile (#4885)Gravatar Fred K. Bot 1-86/+79
2022-09-26[ci] formatGravatar bholmesdev 3-23/+19
2022-09-26Fix: correctly transform `import.meta.env.*` in MDX (#4858)Gravatar Ben Holmes 12-233/+454
2022-09-26Change negative lookbehind to lookahead (#4866)Gravatar Rishi Raj Jain 1-1/+1
2022-09-26add double check on astro file return type to display more human readable err...Gravatar Steven Yung 6-2/+61
2022-09-26[ci] update lockfile (#4862)Gravatar Fred K. Bot 1-81/+81
2022-09-26fix: Script with innerHTML not working on Safari (#4861)Gravatar Rishi Raj Jain 3-3/+10
2022-09-26Prevent /undefined catch-all routes in dev (#4873)Gravatar Bjorn Lu 6-9/+66
2022-09-26fix: 🐛 BUG: class:list directive adding class attribute when undefined (#4...Gravatar Rishi Raj Jain 2-2/+9
2022-09-26docs: Standardize common integration READMEs (#4874)Gravatar Jake Strawn 7-6/+66
2022-09-26docs: Update references to support channel in Discord. (#4872)Gravatar Jake Strawn 12-12/+12
2022-09-26[ci] formatGravatar bluwy 1-1/+1
2022-09-26fix: "chunks" directory appears in build output, if custom modules are import...Gravatar Rishi Raj Jain 2-6/+34
2022-09-23[ci] formatGravatar matthewp 1-1/+1
2022-09-23Define toStringTag another way (#4855)Gravatar Matthew Phillips 2-4/+12
2022-09-23update SSR example to match recent change on Astro API Context (#4854)Gravatar Steven Yung 2-4/+6
2022-09-23[ci] update lockfile (#4852)Gravatar Fred K. Bot 1-373/+402