2017-09-23 08:56:58 +03:00
|
|
|
// Copyright 2015 Light Code Labs, LLC
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2016-06-06 06:51:56 +03:00
|
|
|
package internalsrv
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
fix lint warnings (issue 2541) (#2551)
* Lint: fix some errcheck #2541
* Lint: fix passing structcheck #2541
* Lint: update fix structcheck #2541
* Lint: fix errcheck for basicauth, browse, fastcgi_test #2541
* Lint: fix errcheck for browse, fastcgi_test, fcgiclient, fcgiclient_test #2541
* Lint: fix errcheck for responsefilter_test, fcgilient_test #2541
* Lint: fix errcheck for header_test #2541
* Lint: update errcheck for fcgiclient_test #2541
* Lint: fix errcheck for server, header_test, fastcgi_test, https_test, recorder_test #2541
* Lint: fix errcheck for tplcontext, vhosttrie_test, internal_test, handler_test #2541
* Lint: fix errcheck for log_test, markdown mholt#2541
* Lint: fix errcheck for policy, body_test, proxy_test #2541
* Lint: fix errcheck for on multiple packages #2541
- reverseproxy
- reverseproxy_test
- upstream
- upstream_test
- body_test
* Lint: fix errcheck in multiple packages mholt#2541
- handler_test
- redirect_test
- requestid_test
- rewrite_test
- fileserver_test
* Lint: fix errcheck in multiple packages mholt#2541
- websocket
- setup
- collection
- redirect_test
- templates_test
* Lint: fix errcheck in logger test #2541
run goimports against #2551
- lexer_test
- log_test
- markdown
* Update caddyhttp/httpserver/logger_test.go
Co-Authored-By: Inconnu08 <taufiqrx8@gmail.com>
* Update log_test.go
* Lint: fix scope in logger_test #2541
* remove redundant err check in logger_test #2541
* fix alias in logger_test #2541
* fix import for format #2541
* refactor variable names and error check #2541
2019-04-22 19:20:37 +03:00
|
|
|
"log"
|
2016-06-06 06:51:56 +03:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"testing"
|
|
|
|
|
2016-08-08 08:16:33 +03:00
|
|
|
"strconv"
|
2017-02-08 18:02:09 +03:00
|
|
|
|
|
|
|
"github.com/mholt/caddy/caddyhttp/httpserver"
|
2016-08-08 08:16:33 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
internalProtectedData = "~~~protected-data~~~"
|
|
|
|
contentTypeOctetStream = "application/octet-stream"
|
2016-06-06 06:51:56 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestInternal(t *testing.T) {
|
|
|
|
im := Internal{
|
|
|
|
Next: httpserver.HandlerFunc(internalTestHandlerFunc),
|
|
|
|
Paths: []string{"/internal"},
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
url string
|
|
|
|
expectedCode int
|
|
|
|
expectedBody string
|
|
|
|
}{
|
|
|
|
{"/internal", http.StatusNotFound, ""},
|
|
|
|
|
|
|
|
{"/public", 0, "/public"},
|
|
|
|
{"/public/internal", 0, "/public/internal"},
|
|
|
|
|
|
|
|
{"/redirect", 0, "/internal"},
|
|
|
|
|
|
|
|
{"/cycle", http.StatusInternalServerError, ""},
|
|
|
|
}
|
|
|
|
|
2016-08-08 08:16:33 +03:00
|
|
|
var i int
|
2016-06-06 06:51:56 +03:00
|
|
|
for i, test := range tests {
|
|
|
|
req, err := http.NewRequest("GET", test.url, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test %d: Could not create HTTP request: %v", i, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
code, _ := im.ServeHTTP(rec, req)
|
|
|
|
|
|
|
|
if code != test.expectedCode {
|
|
|
|
t.Errorf("Test %d: Expected status code %d for %s, but got %d",
|
|
|
|
i, test.expectedCode, test.url, code)
|
|
|
|
}
|
|
|
|
if rec.Body.String() != test.expectedBody {
|
|
|
|
t.Errorf("Test %d: Expected body '%s' for %s, but got '%s'",
|
|
|
|
i, test.expectedBody, test.url, rec.Body.String())
|
|
|
|
}
|
|
|
|
}
|
2016-08-08 08:16:33 +03:00
|
|
|
|
|
|
|
{
|
|
|
|
req, err := http.NewRequest("GET", "/download", nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Test %d: Could not create HTTP request: %v", i, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
rec := httptest.NewRecorder()
|
|
|
|
code, _ := im.ServeHTTP(rec, req)
|
|
|
|
|
|
|
|
if code != 0 {
|
|
|
|
t.Errorf("Test %d: Expected status code %d for %s, but got %d",
|
|
|
|
i, 0, "/download", code)
|
|
|
|
}
|
|
|
|
if rec.Body.String() != internalProtectedData {
|
|
|
|
t.Errorf("Test %d: Expected body '%s' for %s, but got '%s'",
|
|
|
|
i, internalProtectedData, "/download", rec.Body.String())
|
|
|
|
}
|
|
|
|
contentLength, err := strconv.Atoi(rec.Header().Get("Content-Length"))
|
|
|
|
if err != nil || contentLength != len(internalProtectedData) {
|
|
|
|
t.Errorf("Test %d: Expected content-length %d for %s, but got %d",
|
|
|
|
i, len(internalProtectedData), "/download", contentLength)
|
|
|
|
}
|
|
|
|
if val := rec.Header().Get("Content-Type"); val != contentTypeOctetStream {
|
|
|
|
t.Errorf("Test %d: Expected content-type '%s' header for %s, but got '%s'",
|
|
|
|
i, contentTypeOctetStream, "/download", val)
|
|
|
|
}
|
|
|
|
if val := rec.Header().Get("Content-Disposition"); val == "" {
|
|
|
|
t.Errorf("Test %d: Expected content-disposition header for %s",
|
|
|
|
i, "/download")
|
|
|
|
}
|
|
|
|
if val := rec.Header().Get("Content-Encoding"); val != "" {
|
|
|
|
t.Errorf("Test %d: Expected removal of content-encoding header for %s",
|
|
|
|
i, "/download")
|
|
|
|
}
|
|
|
|
}
|
2016-06-06 06:51:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func internalTestHandlerFunc(w http.ResponseWriter, r *http.Request) (int, error) {
|
|
|
|
switch r.URL.Path {
|
|
|
|
case "/redirect":
|
|
|
|
w.Header().Set("X-Accel-Redirect", "/internal")
|
2016-08-08 08:16:33 +03:00
|
|
|
|
2016-06-06 06:51:56 +03:00
|
|
|
case "/cycle":
|
|
|
|
w.Header().Set("X-Accel-Redirect", "/cycle")
|
2016-08-08 08:16:33 +03:00
|
|
|
|
|
|
|
case "/download":
|
|
|
|
w.Header().Set("X-Accel-Redirect", "/internal/data")
|
|
|
|
w.Header().Set("Content-Disposition", "attachment; filename=test")
|
|
|
|
w.Header().Set("Content-Encoding", "magic")
|
|
|
|
w.Header().Set("Content-Length", "999")
|
|
|
|
|
|
|
|
case "/internal/data":
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
w.Header().Set("Content-Type", contentTypeOctetStream)
|
|
|
|
w.Header().Set("Content-Length", strconv.Itoa(len(internalProtectedData)))
|
fix lint warnings (issue 2541) (#2551)
* Lint: fix some errcheck #2541
* Lint: fix passing structcheck #2541
* Lint: update fix structcheck #2541
* Lint: fix errcheck for basicauth, browse, fastcgi_test #2541
* Lint: fix errcheck for browse, fastcgi_test, fcgiclient, fcgiclient_test #2541
* Lint: fix errcheck for responsefilter_test, fcgilient_test #2541
* Lint: fix errcheck for header_test #2541
* Lint: update errcheck for fcgiclient_test #2541
* Lint: fix errcheck for server, header_test, fastcgi_test, https_test, recorder_test #2541
* Lint: fix errcheck for tplcontext, vhosttrie_test, internal_test, handler_test #2541
* Lint: fix errcheck for log_test, markdown mholt#2541
* Lint: fix errcheck for policy, body_test, proxy_test #2541
* Lint: fix errcheck for on multiple packages #2541
- reverseproxy
- reverseproxy_test
- upstream
- upstream_test
- body_test
* Lint: fix errcheck in multiple packages mholt#2541
- handler_test
- redirect_test
- requestid_test
- rewrite_test
- fileserver_test
* Lint: fix errcheck in multiple packages mholt#2541
- websocket
- setup
- collection
- redirect_test
- templates_test
* Lint: fix errcheck in logger test #2541
run goimports against #2551
- lexer_test
- log_test
- markdown
* Update caddyhttp/httpserver/logger_test.go
Co-Authored-By: Inconnu08 <taufiqrx8@gmail.com>
* Update log_test.go
* Lint: fix scope in logger_test #2541
* remove redundant err check in logger_test #2541
* fix alias in logger_test #2541
* fix import for format #2541
* refactor variable names and error check #2541
2019-04-22 19:20:37 +03:00
|
|
|
if _, err := w.Write([]byte(internalProtectedData)); err != nil {
|
|
|
|
log.Println("[ERROR] failed to write bytes: ", err)
|
|
|
|
}
|
2016-08-08 08:16:33 +03:00
|
|
|
return 0, nil
|
2016-06-06 06:51:56 +03:00
|
|
|
}
|
2016-08-08 08:16:33 +03:00
|
|
|
|
2016-06-06 06:51:56 +03:00
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
fmt.Fprintf(w, r.URL.String())
|
|
|
|
|
|
|
|
return 0, nil
|
|
|
|
}
|