Giant blob of minor changes
[dotfiles/.git] / .config / coc / extensions / coc-go-data / tools / pkg / mod / golang.org / x / tools@v0.0.0-20201105173854-bc9fc8d8c4bc / go / analysis / passes / httpresponse / testdata / src / a / a.go
diff --git a/.config/coc/extensions/coc-go-data/tools/pkg/mod/golang.org/x/tools@v0.0.0-20201105173854-bc9fc8d8c4bc/go/analysis/passes/httpresponse/testdata/src/a/a.go b/.config/coc/extensions/coc-go-data/tools/pkg/mod/golang.org/x/tools@v0.0.0-20201105173854-bc9fc8d8c4bc/go/analysis/passes/httpresponse/testdata/src/a/a.go
new file mode 100644 (file)
index 0000000..df7703f
--- /dev/null
@@ -0,0 +1,85 @@
+package a
+
+import (
+       "log"
+       "net/http"
+)
+
+func goodHTTPGet() {
+       res, err := http.Get("http://foo.com")
+       if err != nil {
+               log.Fatal(err)
+       }
+       defer res.Body.Close()
+}
+
+func badHTTPGet() {
+       res, err := http.Get("http://foo.com")
+       defer res.Body.Close() // want "using res before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}
+
+func badHTTPHead() {
+       res, err := http.Head("http://foo.com")
+       defer res.Body.Close() // want "using res before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}
+
+func goodClientGet() {
+       client := http.DefaultClient
+       res, err := client.Get("http://foo.com")
+       if err != nil {
+               log.Fatal(err)
+       }
+       defer res.Body.Close()
+}
+
+func badClientPtrGet() {
+       client := http.DefaultClient
+       resp, err := client.Get("http://foo.com")
+       defer resp.Body.Close() // want "using resp before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}
+
+func badClientGet() {
+       client := http.Client{}
+       resp, err := client.Get("http://foo.com")
+       defer resp.Body.Close() // want "using resp before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}
+
+func badClientPtrDo() {
+       client := http.DefaultClient
+       req, err := http.NewRequest("GET", "http://foo.com", nil)
+       if err != nil {
+               log.Fatal(err)
+       }
+
+       resp, err := client.Do(req)
+       defer resp.Body.Close() // want "using resp before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}
+
+func badClientDo() {
+       var client http.Client
+       req, err := http.NewRequest("GET", "http://foo.com", nil)
+       if err != nil {
+               log.Fatal(err)
+       }
+
+       resp, err := client.Do(req)
+       defer resp.Body.Close() // want "using resp before checking for errors"
+       if err != nil {
+               log.Fatal(err)
+       }
+}