remove Proxy pointer from TransformingTransport

This pointer was only needed to pass along the scaleUp option.  In order
to prevent someone from specifying the scaleUp option on an individual
request against the owner's wishes, we didn't encode or decode that
field on the Options struct.  Instead, we stored the value on the Proxy
object and then set it on the Options struct inside the
TransformingTransport.  This worked, but I never really liked binding
those two together.

Instead, we now treat scaleUp as a normal Option field, encoding and
decoding it with all the others.  The primary difference is that the
initial value from the request URL will always be overwritten with
whatever is set in Proxy.ScaleUp.  This decouples the
TransformingTransport from the Proxy, but prevents the option from being
set in the request URL.

Modifies #37
This commit is contained in:
Will Norris 2015-12-07 23:06:02 -08:00
parent b967dc69a9
commit b4216d8da8
3 changed files with 12 additions and 21 deletions

View file

@ -12,8 +12,6 @@ import (
"net/url"
"strings"
"testing"
"github.com/gregjones/httpcache"
)
func TestAllowed(t *testing.T) {
@ -206,15 +204,6 @@ func TestCheck304(t *testing.T) {
}
}
// make sure that the proxy is passed to transport in order
// to access the command line flags.
func TestProxyPointer(t *testing.T) {
p := NewProxy(nil, nil)
if p.Client.Transport.(*httpcache.Transport).Transport.(*TransformingTransport).Proxy != p {
t.Errorf("Transport doesnt have proxy pointer")
}
}
// testTransport is an http.RoundTripper that returns certained canned
// responses for particular requests.
type testTransport struct{}