// New creates a new default runtime for a swagger api client. func New(host, basePath string, schemes []string) *Runtime { var rt Runtime rt.DefaultMediaType = httpkit.JSONMime // TODO: actually infer this stuff from the spec rt.Consumers = map[string]httpkit.Consumer{ httpkit.JSONMime: httpkit.JSONConsumer(), httpkit.XMLMime: httpkit.XMLConsumer(), httpkit.TextMime: httpkit.TextConsumer(), } rt.Producers = map[string]httpkit.Producer{ httpkit.JSONMime: httpkit.JSONProducer(), httpkit.XMLMime: httpkit.XMLProducer(), httpkit.TextMime: httpkit.TextProducer(), } rt.Transport = http.DefaultTransport rt.Jar = nil rt.Host = host rt.BasePath = basePath rt.Context = context.Background() rt.clientOnce = new(sync.Once) if !strings.HasPrefix(rt.BasePath, "/") { rt.BasePath = "/" + rt.BasePath } rt.Debug = os.Getenv("DEBUG") == "1" if len(schemes) > 0 { rt.schemes = schemes } return &rt }
"io/ioutil" "mime" "mime/multipart" "os" "path/filepath" "testing" "github.com/go-swagger/go-swagger/client" "github.com/go-swagger/go-swagger/httpkit" "github.com/go-swagger/go-swagger/strfmt" "github.com/stretchr/testify/assert" ) var testProducers = map[string]httpkit.Producer{ httpkit.JSONMime: httpkit.JSONProducer(), httpkit.XMLMime: httpkit.XMLProducer(), httpkit.TextMime: httpkit.TextProducer(), } func TestBuildRequest_SetHeaders(t *testing.T) { r, _ := newRequest("GET", "/flats/{id}/", nil) // single value r.SetHeaderParam("X-Rate-Limit", "500") assert.Equal(t, "500", r.header.Get("X-Rate-Limit")) r.SetHeaderParam("X-Rate-Limit", "400") assert.Equal(t, "400", r.header.Get("X-Rate-Limit")) // multi value r.SetHeaderParam("X-Accepts", "json", "xml", "yaml") assert.EqualValues(t, []string{"json", "xml", "yaml"}, r.header["X-Accepts"]) }