123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406 |
- package api
- import (
- "bytes"
- "encoding/json"
- "errors"
- "fmt"
- "io"
- "net/http"
- "os"
- "regexp"
- "runtime"
- "testing"
- "github.com/docker/docker/pkg/reexec"
- "github.com/docker/libnetwork"
- "github.com/docker/libnetwork/datastore"
- "github.com/docker/libnetwork/drivers/bridge"
- "github.com/docker/libnetwork/netlabel"
- "github.com/docker/libnetwork/options"
- "github.com/docker/libnetwork/testutils"
- "github.com/docker/libnetwork/types"
- )
- const (
- bridgeNetType = "bridge"
- bridgeName = "docker0"
- )
- func i2s(i interface{}) string {
- s, ok := i.(string)
- if !ok {
- panic(fmt.Sprintf("Failed i2s for %v", i))
- }
- return s
- }
- func i2e(i interface{}) *endpointResource {
- s, ok := i.(*endpointResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2e for %v", i))
- }
- return s
- }
- func i2eL(i interface{}) []*endpointResource {
- s, ok := i.([]*endpointResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2eL for %v", i))
- }
- return s
- }
- func i2n(i interface{}) *networkResource {
- s, ok := i.(*networkResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2n for %v", i))
- }
- return s
- }
- func i2nL(i interface{}) []*networkResource {
- s, ok := i.([]*networkResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2nL for %v", i))
- }
- return s
- }
- func i2sb(i interface{}) *sandboxResource {
- s, ok := i.(*sandboxResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2sb for %v", i))
- }
- return s
- }
- func i2sbL(i interface{}) []*sandboxResource {
- s, ok := i.([]*sandboxResource)
- if !ok {
- panic(fmt.Sprintf("Failed i2sbL for %v", i))
- }
- return s
- }
- func createTestNetwork(t *testing.T, network string) (libnetwork.NetworkController, libnetwork.Network) {
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- netOption := options.Generic{
- netlabel.GenericData: options.Generic{
- "BridgeName": network,
- },
- }
- netGeneric := libnetwork.NetworkOptionGeneric(netOption)
- nw, err := c.NewNetwork(bridgeNetType, network, netGeneric)
- if err != nil {
- t.Fatal(err)
- }
- return c, nw
- }
- func getExposedPorts() []types.TransportPort {
- return []types.TransportPort{
- types.TransportPort{Proto: types.TCP, Port: uint16(5000)},
- types.TransportPort{Proto: types.UDP, Port: uint16(400)},
- types.TransportPort{Proto: types.TCP, Port: uint16(600)},
- }
- }
- func getPortMapping() []types.PortBinding {
- return []types.PortBinding{
- types.PortBinding{Proto: types.TCP, Port: uint16(230), HostPort: uint16(23000)},
- types.PortBinding{Proto: types.UDP, Port: uint16(200), HostPort: uint16(22000)},
- types.PortBinding{Proto: types.TCP, Port: uint16(120), HostPort: uint16(12000)},
- }
- }
- func TestMain(m *testing.M) {
- if reexec.Init() {
- return
- }
- os.Exit(m.Run())
- }
- func TestSandboxOptionParser(t *testing.T) {
- hn := "host1"
- dn := "docker.com"
- hp := "/etc/hosts"
- rc := "/etc/resolv.conf"
- dnss := []string{"8.8.8.8", "172.28.34.5"}
- ehs := []extraHost{extraHost{Name: "extra1", Address: "172.28.9.1"}, extraHost{Name: "extra2", Address: "172.28.9.2"}}
- sb := sandboxCreate{
- HostName: hn,
- DomainName: dn,
- HostsPath: hp,
- ResolvConfPath: rc,
- DNS: dnss,
- ExtraHosts: ehs,
- UseDefaultSandbox: true,
- }
- if len(sb.parseOptions()) != 9 {
- t.Fatalf("Failed to generate all libnetwork.SandboxOption methods")
- }
- }
- func TestJson(t *testing.T) {
- nc := networkCreate{NetworkType: bridgeNetType}
- b, err := json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- var ncp networkCreate
- err = json.Unmarshal(b, &ncp)
- if err != nil {
- t.Fatal(err)
- }
- if nc.NetworkType != ncp.NetworkType {
- t.Fatalf("Incorrect networkCreate after json encoding/deconding: %v", ncp)
- }
- jl := endpointJoin{SandboxID: "abcdef456789"}
- b, err = json.Marshal(jl)
- if err != nil {
- t.Fatal(err)
- }
- var jld endpointJoin
- err = json.Unmarshal(b, &jld)
- if err != nil {
- t.Fatal(err)
- }
- if jl.SandboxID != jld.SandboxID {
- t.Fatalf("Incorrect endpointJoin after json encoding/deconding: %v", jld)
- }
- }
- func TestCreateDeleteNetwork(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- badBody, err := json.Marshal("bad body")
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- _, errRsp := procCreateNetwork(c, nil, badBody)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
- }
- incompleteBody, err := json.Marshal(networkCreate{})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procCreateNetwork(c, vars, incompleteBody)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected StatusBadRequest status code, got: %v", errRsp)
- }
- ops := map[string]string{
- bridge.BridgeName: "abc",
- netlabel.EnableIPv6: "true",
- }
- nc := networkCreate{Name: "network_1", NetworkType: bridgeNetType, DriverOpts: ops}
- goodBody, err := json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procCreateNetwork(c, vars, goodBody)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- vars[urlNwName] = ""
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- vars[urlNwName] = "abc"
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- vars[urlNwName] = "network_1"
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- // Create with labels
- labels := map[string]string{
- netlabel.EnableIPv6: "true",
- bridge.BridgeName: "abc",
- }
- nc = networkCreate{Name: "network_2", NetworkType: bridgeNetType, DriverOpts: labels}
- goodBody, err = json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procCreateNetwork(c, vars, goodBody)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- vars[urlNwName] = "network_2"
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- }
- func TestGetNetworksAndEndpoints(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- ops := map[string]string{
- bridge.BridgeName: "api_test_nw",
- }
- nc := networkCreate{Name: "sh", NetworkType: bridgeNetType, DriverOpts: ops}
- body, err := json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- inid, errRsp := procCreateNetwork(c, vars, body)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- nid, ok := inid.(string)
- if !ok {
- t.FailNow()
- }
- ec1 := endpointCreate{
- Name: "ep1",
- ExposedPorts: getExposedPorts(),
- PortMapping: getPortMapping(),
- }
- b1, err := json.Marshal(ec1)
- if err != nil {
- t.Fatal(err)
- }
- ec2 := endpointCreate{Name: "ep2"}
- b2, err := json.Marshal(ec2)
- if err != nil {
- t.Fatal(err)
- }
- vars[urlNwName] = "sh"
- vars[urlEpName] = "ep1"
- ieid1, errRsp := procCreateEndpoint(c, vars, b1)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- eid1 := i2s(ieid1)
- vars[urlEpName] = "ep2"
- ieid2, errRsp := procCreateEndpoint(c, vars, b2)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- eid2 := i2s(ieid2)
- vars[urlNwName] = ""
- vars[urlEpName] = "ep1"
- _, errRsp = procGetEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure but succeeded: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
- }
- vars = make(map[string]string)
- vars[urlNwName] = "sh"
- vars[urlEpID] = ""
- _, errRsp = procGetEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure but succeeded: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
- }
- vars = make(map[string]string)
- vars[urlNwID] = ""
- vars[urlEpID] = eid1
- _, errRsp = procGetEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure but succeeded: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected to fail with http.StatusBadRequest, but got: %d", errRsp.StatusCode)
- }
- // nw by name and ep by id
- vars[urlNwName] = "sh"
- i1, errRsp := procGetEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- // nw by name and ep by name
- delete(vars, urlEpID)
- vars[urlEpName] = "ep1"
- i2, errRsp := procGetEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- // nw by id and ep by name
- delete(vars, urlNwName)
- vars[urlNwID] = nid
- i3, errRsp := procGetEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- // nw by id and ep by id
- delete(vars, urlEpName)
- vars[urlEpID] = eid1
- i4, errRsp := procGetEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- id1 := i2e(i1).ID
- if id1 != i2e(i2).ID || id1 != i2e(i3).ID || id1 != i2e(i4).ID {
- t.Fatalf("Endpoints retireved via different query parameters differ: %v, %v, %v, %v", i1, i2, i3, i4)
- }
- vars[urlNwName] = ""
- _, errRsp = procGetEndpoints(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- delete(vars, urlNwName)
- vars[urlNwID] = "fakeID"
- _, errRsp = procGetEndpoints(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlNwID] = nid
- _, errRsp = procGetEndpoints(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- vars[urlNwName] = "sh"
- iepList, errRsp := procGetEndpoints(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- epList := i2eL(iepList)
- if len(epList) != 2 {
- t.Fatalf("Did not return the expected number (2) of endpoint resources: %d", len(epList))
- }
- if "sh" != epList[0].Network || "sh" != epList[1].Network {
- t.Fatalf("Did not find expected network name in endpoint resources")
- }
- vars = make(map[string]string)
- vars[urlNwName] = ""
- _, errRsp = procGetNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Exepected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "shhhhh"
- _, errRsp = procGetNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Exepected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "sh"
- inr1, errRsp := procGetNetwork(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- nr1 := i2n(inr1)
- delete(vars, urlNwName)
- vars[urlNwID] = "acacac"
- _, errRsp = procGetNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure. Got: %v", errRsp)
- }
- vars[urlNwID] = nid
- inr2, errRsp := procGetNetwork(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("procgetNetworkByName() != procgetNetworkById(), %v vs %v", inr1, inr2)
- }
- nr2 := i2n(inr2)
- if nr1.Name != nr2.Name || nr1.Type != nr2.Type || nr1.ID != nr2.ID || len(nr1.Endpoints) != len(nr2.Endpoints) {
- t.Fatalf("Get by name and Get failure: %v", errRsp)
- }
- if len(nr1.Endpoints) != 2 {
- t.Fatalf("Did not find the expected number (2) of endpoint resources in the network resource: %d", len(nr1.Endpoints))
- }
- for _, er := range nr1.Endpoints {
- if er.ID != eid1 && er.ID != eid2 {
- t.Fatalf("Did not find the expected endpoint resources in the network resource: %v", nr1.Endpoints)
- }
- }
- iList, errRsp := procGetNetworks(c, nil, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- netList := i2nL(iList)
- if len(netList) != 1 {
- t.Fatalf("Did not return the expected number of network resources")
- }
- if nid != netList[0].ID {
- t.Fatalf("Did not find expected network %s: %v", nid, netList)
- }
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Exepected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "ep1"
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- delete(vars, urlEpName)
- iepList, errRsp = procGetEndpoints(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- epList = i2eL(iepList)
- if len(epList) != 1 {
- t.Fatalf("Did not return the expected number (1) of endpoint resources: %d", len(epList))
- }
- vars[urlEpName] = "ep2"
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- iepList, errRsp = procGetEndpoints(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- epList = i2eL(iepList)
- if len(epList) != 0 {
- t.Fatalf("Did not return the expected number (0) of endpoint resources: %d", len(epList))
- }
- _, errRsp = procDeleteNetwork(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- iList, errRsp = procGetNetworks(c, nil, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- netList = i2nL(iList)
- if len(netList) != 0 {
- t.Fatalf("Did not return the expected number of network resources")
- }
- }
- func TestProcGetServices(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- // Create 2 networks
- netName1 := "production"
- netOption := options.Generic{
- netlabel.GenericData: options.Generic{
- "BridgeName": netName1,
- },
- }
- nw1, err := c.NewNetwork(bridgeNetType, netName1, libnetwork.NetworkOptionGeneric(netOption))
- if err != nil {
- t.Fatal(err)
- }
- netName2 := "work-dev"
- netOption = options.Generic{
- netlabel.GenericData: options.Generic{
- "BridgeName": netName2,
- },
- }
- nw2, err := c.NewNetwork(bridgeNetType, netName2, libnetwork.NetworkOptionGeneric(netOption))
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- li, errRsp := procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list := i2eL(li)
- if len(list) != 0 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- // Add a couple of services on one network and one on the other network
- ep11, err := nw1.CreateEndpoint("db-prod")
- if err != nil {
- t.Fatal(err)
- }
- ep12, err := nw1.CreateEndpoint("web-prod")
- if err != nil {
- t.Fatal(err)
- }
- ep21, err := nw2.CreateEndpoint("db-dev")
- if err != nil {
- t.Fatal(err)
- }
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 3 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- // Filter by network
- vars[urlNwName] = netName1
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 2 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- vars[urlNwName] = netName2
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 1 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- vars[urlNwName] = "unknown-network"
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 0 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- // Query by name
- delete(vars, urlNwName)
- vars[urlEpName] = "db-prod"
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 1 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- vars[urlEpName] = "no-service"
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 0 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- // Query by id or partial id
- delete(vars, urlEpName)
- vars[urlEpPID] = ep12.ID()
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 1 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- if list[0].ID != ep12.ID() {
- t.Fatalf("Unexpected element in response: %v", list)
- }
- vars[urlEpPID] = "non-id"
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 0 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- delete(vars, urlEpPID)
- err = ep11.Delete()
- if err != nil {
- t.Fatal(err)
- }
- err = ep12.Delete()
- if err != nil {
- t.Fatal(err)
- }
- err = ep21.Delete()
- if err != nil {
- t.Fatal(err)
- }
- li, errRsp = procGetServices(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- list = i2eL(li)
- if len(list) != 0 {
- t.Fatalf("Unexpected services in response: %v", list)
- }
- }
- func TestProcGetService(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, nw := createTestNetwork(t, "network")
- defer c.Stop()
- ep1, err := nw.CreateEndpoint("db")
- if err != nil {
- t.Fatal(err)
- }
- ep2, err := nw.CreateEndpoint("web")
- if err != nil {
- t.Fatal(err)
- }
- vars := map[string]string{urlEpID: ""}
- _, errRsp := procGetService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure, but suceeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
- }
- vars[urlEpID] = "unknown-service-id"
- _, errRsp = procGetService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure, but suceeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d. (%v)", http.StatusNotFound, errRsp.StatusCode, errRsp)
- }
- vars[urlEpID] = ep1.ID()
- si, errRsp := procGetService(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- sv := i2e(si)
- if sv.ID != ep1.ID() {
- t.Fatalf("Unexpected service resource returned: %v", sv)
- }
- vars[urlEpID] = ep2.ID()
- si, errRsp = procGetService(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- sv = i2e(si)
- if sv.ID != ep2.ID() {
- t.Fatalf("Unexpected service resource returned: %v", sv)
- }
- }
- func TestProcPublishUnpublishService(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, _ := createTestNetwork(t, "network")
- defer c.Stop()
- vars := make(map[string]string)
- vbad, err := json.Marshal("bad service create data")
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp := procPublishService(c, vars, vbad)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- b, err := json.Marshal(servicePublish{Name: ""})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procPublishService(c, vars, b)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- b, err = json.Marshal(servicePublish{Name: "db"})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procPublishService(c, vars, b)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- b, err = json.Marshal(servicePublish{Name: "db", Network: "unknown-network"})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procPublishService(c, vars, b)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
- }
- b, err = json.Marshal(servicePublish{Name: "", Network: "network"})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procPublishService(c, vars, b)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- b, err = json.Marshal(servicePublish{Name: "db", Network: "network"})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procPublishService(c, vars, b)
- if errRsp != &createdResponse {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- sp := servicePublish{
- Name: "web",
- Network: "network",
- ExposedPorts: getExposedPorts(),
- PortMapping: getPortMapping(),
- }
- b, err = json.Marshal(sp)
- if err != nil {
- t.Fatal(err)
- }
- si, errRsp := procPublishService(c, vars, b)
- if errRsp != &createdResponse {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- sid := i2s(si)
- vars[urlEpID] = ""
- _, errRsp = procUnpublishService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- vars[urlEpID] = "unknown-service-id"
- _, errRsp = procUnpublishService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure but succeeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
- }
- vars[urlEpID] = sid
- _, errRsp = procUnpublishService(c, vars, nil)
- if !errRsp.isOK() {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- _, errRsp = procGetService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure, but suceeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d. (%v)", http.StatusNotFound, errRsp.StatusCode, errRsp)
- }
- }
- func TestAttachDetachBackend(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, nw := createTestNetwork(t, "network")
- defer c.Stop()
- ep1, err := nw.CreateEndpoint("db")
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- vbad, err := json.Marshal("bad data")
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp := procAttachBackend(c, vars, vbad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "endpoint"
- bad, err := json.Marshal(endpointJoin{})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procAttachBackend(c, vars, bad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
- }
- vars[urlEpID] = "db"
- _, errRsp = procGetSandbox(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure. Got %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
- }
- vars[urlEpName] = "db"
- _, errRsp = procAttachBackend(c, vars, bad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- cid := "abcdefghi"
- sbox, err := c.NewSandbox(cid)
- sid := sbox.ID()
- defer sbox.Delete()
- jl := endpointJoin{SandboxID: sid}
- jlb, err := json.Marshal(jl)
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procAttachBackend(c, vars, jlb)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure, got: %v", errRsp)
- }
- sli, errRsp := procGetSandboxes(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure, got: %v", errRsp)
- }
- sl := i2sbL(sli)
- if len(sl) != 1 {
- t.Fatalf("Did not find expected number of sandboxes attached to the service: %d", len(sl))
- }
- if sl[0].ContainerID != cid {
- t.Fatalf("Did not find expected sandbox attached to the service: %v", sl[0])
- }
- _, errRsp = procUnpublishService(c, vars, nil)
- if errRsp.isOK() {
- t.Fatalf("Expected failure but succeeded")
- }
- if errRsp.StatusCode != http.StatusForbidden {
- t.Fatalf("Expected %d. Got: %v", http.StatusForbidden, errRsp)
- }
- vars[urlEpName] = "endpoint"
- _, errRsp = procDetachBackend(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d. Got: %v", http.StatusNotFound, errRsp)
- }
- vars[urlEpName] = "db"
- _, errRsp = procDetachBackend(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- vars[urlSbID] = sid
- _, errRsp = procDetachBackend(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure, got: %v", errRsp)
- }
- delete(vars, urlEpID)
- si, errRsp := procGetSandbox(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure, got: %v", errRsp)
- }
- sb := i2sb(si)
- if sb.ContainerID != cid {
- t.Fatalf("Did not find expected sandbox. Got %v", sb)
- }
- err = ep1.Delete()
- if err != nil {
- t.Fatal(err)
- }
- }
- func TestDetectGetNetworksInvalidQueryComposition(t *testing.T) {
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- vars := map[string]string{urlNwName: "x", urlNwPID: "y"}
- _, errRsp := procGetNetworks(c, vars, nil)
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- }
- func TestDetectGetEndpointsInvalidQueryComposition(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, _ := createTestNetwork(t, "network")
- defer c.Stop()
- vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
- _, errRsp := procGetEndpoints(c, vars, nil)
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- }
- func TestDetectGetServicesInvalidQueryComposition(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, _ := createTestNetwork(t, "network")
- defer c.Stop()
- vars := map[string]string{urlNwName: "network", urlEpName: "x", urlEpPID: "y"}
- _, errRsp := procGetServices(c, vars, nil)
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d. Got: %v", http.StatusBadRequest, errRsp)
- }
- }
- func TestFindNetworkUtilPanic(t *testing.T) {
- defer checkPanic(t)
- findNetwork(nil, "", -1)
- }
- func TestFindNetworkUtil(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, nw := createTestNetwork(t, "network")
- defer c.Stop()
- nid := nw.ID()
- _, errRsp := findNetwork(c, "", byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
- }
- n, errRsp := findNetwork(c, nid, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- if n == nil {
- t.Fatalf("Unexpected nil libnetwork.Network")
- }
- if nid != n.ID() {
- t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
- }
- if "network" != n.Name() {
- t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
- }
- n, errRsp = findNetwork(c, "network", byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexpected failure: %v", errRsp)
- }
- if n == nil {
- t.Fatalf("Unexpected nil libnetwork.Network")
- }
- if nid != n.ID() {
- t.Fatalf("Incorrect libnetwork.Network resource. It has different id: %v", n)
- }
- if "network" != n.Name() {
- t.Fatalf("Incorrect libnetwork.Network resource. It has different name: %v", n)
- }
- if err := n.Delete(); err != nil {
- t.Fatalf("Failed to delete the network: %s", err.Error())
- }
- _, errRsp = findNetwork(c, nid, byID)
- if errRsp == &successResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findNetwork(c, "network", byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- }
- func TestCreateDeleteEndpoints(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- nc := networkCreate{Name: "firstNet", NetworkType: bridgeNetType}
- body, err := json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- i, errRsp := procCreateNetwork(c, vars, body)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- nid := i2s(i)
- vbad, err := json.Marshal("bad endppoint create data")
- if err != nil {
- t.Fatal(err)
- }
- vars[urlNwName] = "firstNet"
- _, errRsp = procCreateEndpoint(c, vars, vbad)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- b, err := json.Marshal(endpointCreate{Name: ""})
- if err != nil {
- t.Fatal(err)
- }
- vars[urlNwName] = "secondNet"
- _, errRsp = procCreateEndpoint(c, vars, b)
- if errRsp == &createdResponse {
- t.Fatalf("Expected to fail but succeeded")
- }
- vars[urlNwName] = "firstNet"
- _, errRsp = procCreateEndpoint(c, vars, b)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure but succeeded: %v", errRsp)
- }
- b, err = json.Marshal(endpointCreate{Name: "firstEp"})
- if err != nil {
- t.Fatal(err)
- }
- i, errRsp = procCreateEndpoint(c, vars, b)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- eid := i2s(i)
- _, errRsp = findEndpoint(c, "myNet", "firstEp", byName, byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure but succeeded: %v", errRsp)
- }
- ep0, errRsp := findEndpoint(c, nid, "firstEp", byID, byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep1, errRsp := findEndpoint(c, "firstNet", "firstEp", byName, byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep3, errRsp := findEndpoint(c, "firstNet", eid, byName, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() || ep0.ID() != ep3.ID() {
- t.Fatalf("Diffenrent queries returned different endpoints: \nep0: %v\nep1: %v\nep2: %v\nep3: %v", ep0, ep1, ep2, ep3)
- }
- vars = make(map[string]string)
- vars[urlNwName] = ""
- vars[urlEpName] = "ep1"
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "firstNet"
- vars[urlEpName] = ""
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "ep2"
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "firstEp"
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- _, errRsp = findEndpoint(c, "firstNet", "firstEp", byName, byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- }
- func TestJoinLeave(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- nb, err := json.Marshal(networkCreate{Name: "network", NetworkType: bridgeNetType})
- if err != nil {
- t.Fatal(err)
- }
- vars := make(map[string]string)
- _, errRsp := procCreateNetwork(c, vars, nb)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- eb, err := json.Marshal(endpointCreate{Name: "endpoint"})
- if err != nil {
- t.Fatal(err)
- }
- vars[urlNwName] = "network"
- _, errRsp = procCreateEndpoint(c, vars, eb)
- if errRsp != &createdResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- vbad, err := json.Marshal("bad data")
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procJoinEndpoint(c, vars, vbad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "endpoint"
- bad, err := json.Marshal(endpointJoin{})
- if err != nil {
- t.Fatal(err)
- }
- _, errRsp = procJoinEndpoint(c, vars, bad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- cid := "abcdefghi"
- sb, err := c.NewSandbox(cid)
- defer sb.Delete()
- jl := endpointJoin{SandboxID: sb.ID()}
- jlb, err := json.Marshal(jl)
- if err != nil {
- t.Fatal(err)
- }
- vars = make(map[string]string)
- vars[urlNwName] = ""
- vars[urlEpName] = ""
- _, errRsp = procJoinEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "network"
- vars[urlEpName] = ""
- _, errRsp = procJoinEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "epoint"
- _, errRsp = procJoinEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- // bad labels
- vars[urlEpName] = "endpoint"
- key, errRsp := procJoinEndpoint(c, vars, jlb)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure, got: %v", errRsp)
- }
- keyStr := i2s(key)
- if keyStr == "" {
- t.Fatalf("Empty sandbox key")
- }
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "network2"
- _, errRsp = procLeaveEndpoint(c, vars, vbad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- _, errRsp = procLeaveEndpoint(c, vars, bad)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars = make(map[string]string)
- vars[urlNwName] = ""
- vars[urlEpName] = ""
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlNwName] = "network"
- vars[urlEpName] = ""
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "2epoint"
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlEpName] = "epoint"
- vars[urlCnID] = "who"
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- delete(vars, urlCnID)
- vars[urlEpName] = "endpoint"
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- vars[urlSbID] = sb.ID()
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- _, errRsp = procLeaveEndpoint(c, vars, jlb)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, got: %v", errRsp)
- }
- _, errRsp = procDeleteEndpoint(c, vars, nil)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- }
- func TestFindEndpointUtilPanic(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- defer checkPanic(t)
- c, nw := createTestNetwork(t, "network")
- defer c.Stop()
- nid := nw.ID()
- findEndpoint(c, nid, "", byID, -1)
- }
- func TestFindServiceUtilPanic(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- defer checkPanic(t)
- c, _ := createTestNetwork(t, "network")
- defer c.Stop()
- findService(c, "random_service", -1)
- }
- func TestFindEndpointUtil(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- c, nw := createTestNetwork(t, "network")
- defer c.Stop()
- nid := nw.ID()
- ep, err := nw.CreateEndpoint("secondEp", nil)
- if err != nil {
- t.Fatal(err)
- }
- eid := ep.ID()
- _, errRsp := findEndpoint(c, nid, "", byID, byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusBadRequest {
- t.Fatalf("Expected %d, but got: %d", http.StatusBadRequest, errRsp.StatusCode)
- }
- ep0, errRsp := findEndpoint(c, nid, "secondEp", byID, byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep1, errRsp := findEndpoint(c, "network", "secondEp", byName, byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep2, errRsp := findEndpoint(c, nid, eid, byID, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep3, errRsp := findEndpoint(c, "network", eid, byName, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep4, errRsp := findService(c, "secondEp", byName)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- ep5, errRsp := findService(c, eid, byID)
- if errRsp != &successResponse {
- t.Fatalf("Unexepected failure: %v", errRsp)
- }
- if ep0.ID() != ep1.ID() || ep0.ID() != ep2.ID() ||
- ep0.ID() != ep3.ID() || ep0.ID() != ep4.ID() || ep0.ID() != ep5.ID() {
- t.Fatalf("Diffenrent queries returned different endpoints")
- }
- ep.Delete()
- _, errRsp = findEndpoint(c, nid, "secondEp", byID, byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findEndpoint(c, "network", "secondEp", byName, byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findEndpoint(c, nid, eid, byID, byID)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findEndpoint(c, "network", eid, byName, byID)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findService(c, "secondEp", byName)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- _, errRsp = findService(c, eid, byID)
- if errRsp == &successResponse {
- t.Fatalf("Expected failure, but got: %v", errRsp)
- }
- if errRsp.StatusCode != http.StatusNotFound {
- t.Fatalf("Expected %d, but got: %d", http.StatusNotFound, errRsp.StatusCode)
- }
- }
- func TestEndpointToService(t *testing.T) {
- r := &responseStatus{Status: "this is one endpoint", StatusCode: http.StatusOK}
- r = endpointToService(r)
- if r.Status != "this is one service" {
- t.Fatalf("endpointToService returned unexpected status string: %s", r.Status)
- }
- r = &responseStatus{Status: "this is one network", StatusCode: http.StatusOK}
- r = endpointToService(r)
- if r.Status != "this is one network" {
- t.Fatalf("endpointToService returned unexpected status string: %s", r.Status)
- }
- }
- func checkPanic(t *testing.T) {
- if r := recover(); r != nil {
- if _, ok := r.(runtime.Error); ok {
- panic(r)
- }
- } else {
- t.Fatalf("Expected to panic, but suceeded")
- }
- }
- func TestDetectNetworkTargetPanic(t *testing.T) {
- defer checkPanic(t)
- vars := make(map[string]string)
- detectNetworkTarget(vars)
- }
- func TestDetectEndpointTargetPanic(t *testing.T) {
- defer checkPanic(t)
- vars := make(map[string]string)
- detectEndpointTarget(vars)
- }
- func TestResponseStatus(t *testing.T) {
- list := []int{
- http.StatusBadGateway,
- http.StatusBadRequest,
- http.StatusConflict,
- http.StatusContinue,
- http.StatusExpectationFailed,
- http.StatusForbidden,
- http.StatusFound,
- http.StatusGatewayTimeout,
- http.StatusGone,
- http.StatusHTTPVersionNotSupported,
- http.StatusInternalServerError,
- http.StatusLengthRequired,
- http.StatusMethodNotAllowed,
- http.StatusMovedPermanently,
- http.StatusMultipleChoices,
- http.StatusNoContent,
- http.StatusNonAuthoritativeInfo,
- http.StatusNotAcceptable,
- http.StatusNotFound,
- http.StatusNotModified,
- http.StatusPartialContent,
- http.StatusPaymentRequired,
- http.StatusPreconditionFailed,
- http.StatusProxyAuthRequired,
- http.StatusRequestEntityTooLarge,
- http.StatusRequestTimeout,
- http.StatusRequestURITooLong,
- http.StatusRequestedRangeNotSatisfiable,
- http.StatusResetContent,
- http.StatusServiceUnavailable,
- http.StatusSwitchingProtocols,
- http.StatusTemporaryRedirect,
- http.StatusUnauthorized,
- http.StatusUnsupportedMediaType,
- http.StatusUseProxy,
- }
- for _, c := range list {
- r := responseStatus{StatusCode: c}
- if r.isOK() {
- t.Fatalf("isOK() returned true for code% d", c)
- }
- }
- r := responseStatus{StatusCode: http.StatusOK}
- if !r.isOK() {
- t.Fatalf("isOK() failed")
- }
- r = responseStatus{StatusCode: http.StatusCreated}
- if !r.isOK() {
- t.Fatalf("isOK() failed")
- }
- }
- // Local structs for end to end testing of api.go
- type localReader struct {
- data []byte
- beBad bool
- }
- func newLocalReader(data []byte) *localReader {
- lr := &localReader{data: make([]byte, len(data))}
- copy(lr.data, data)
- return lr
- }
- func (l *localReader) Read(p []byte) (n int, err error) {
- if l.beBad {
- return 0, errors.New("I am a bad reader")
- }
- if p == nil {
- return -1, fmt.Errorf("nil buffer passed")
- }
- if l.data == nil || len(l.data) == 0 {
- return 0, io.EOF
- }
- copy(p[:], l.data[:])
- return len(l.data), io.EOF
- }
- type localResponseWriter struct {
- body []byte
- statusCode int
- }
- func newWriter() *localResponseWriter {
- return &localResponseWriter{}
- }
- func (f *localResponseWriter) Header() http.Header {
- return make(map[string][]string, 0)
- }
- func (f *localResponseWriter) Write(data []byte) (int, error) {
- if data == nil {
- return -1, fmt.Errorf("nil data passed")
- }
- f.body = make([]byte, len(data))
- copy(f.body, data)
- return len(f.body), nil
- }
- func (f *localResponseWriter) WriteHeader(c int) {
- f.statusCode = c
- }
- func TestwriteJSON(t *testing.T) {
- testCode := 55
- testData, err := json.Marshal("test data")
- if err != nil {
- t.Fatal(err)
- }
- rsp := newWriter()
- writeJSON(rsp, testCode, testData)
- if rsp.statusCode != testCode {
- t.Fatalf("writeJSON() failed to set the status code. Expected %d. Got %d", testCode, rsp.statusCode)
- }
- if !bytes.Equal(testData, rsp.body) {
- t.Fatalf("writeJSON() failed to set the body. Expected %s. Got %s", testData, rsp.body)
- }
- }
- func TestHttpHandlerUninit(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- h := &httpHandler{c: c}
- h.initRouter()
- if h.r == nil {
- t.Fatalf("initRouter() did not initialize the router")
- }
- rsp := newWriter()
- req, err := http.NewRequest("GET", "/v1.19/networks", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest := NewHTTPHandler(nil)
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusServiceUnavailable {
- t.Fatalf("Expected (%d). Got (%d): %s", http.StatusServiceUnavailable, rsp.statusCode, rsp.body)
- }
- handleRequest = NewHTTPHandler(c)
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected (%d). Got: (%d): %s", http.StatusOK, rsp.statusCode, rsp.body)
- }
- var list []*networkResource
- err = json.Unmarshal(rsp.body, &list)
- if err != nil {
- t.Fatal(err)
- }
- if len(list) != 0 {
- t.Fatalf("Expected empty list. Got %v", list)
- }
- n, err := c.NewNetwork(bridgeNetType, "didietro", nil)
- if err != nil {
- t.Fatal(err)
- }
- nwr := buildNetworkResource(n)
- expected, err := json.Marshal([]*networkResource{nwr})
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- if len(rsp.body) == 0 {
- t.Fatalf("Empty list of networks")
- }
- if bytes.Equal(rsp.body, expected) {
- t.Fatalf("Incorrect list of networks in response's body")
- }
- }
- func TestHttpHandlerBadBody(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- rsp := newWriter()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- handleRequest := NewHTTPHandler(c)
- req, err := http.NewRequest("POST", "/v1.19/networks", &localReader{beBad: true})
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusBadRequest {
- t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
- }
- body := []byte{}
- lr := newLocalReader(body)
- req, err = http.NewRequest("POST", "/v1.19/networks", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusBadRequest {
- t.Fatalf("Unexpected status code. Expected (%d). Got (%d): %s.", http.StatusBadRequest, rsp.statusCode, string(rsp.body))
- }
- }
- func TestEndToEnd(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- rsp := newWriter()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- handleRequest := NewHTTPHandler(c)
- ops := map[string]string{
- bridge.BridgeName: "cdef",
- netlabel.EnableIPv6: "true",
- netlabel.DriverMTU: "1460",
- }
- // Create network
- nc := networkCreate{Name: "network-fiftyfive", NetworkType: bridgeNetType, DriverOpts: ops}
- body, err := json.Marshal(nc)
- if err != nil {
- t.Fatal(err)
- }
- lr := newLocalReader(body)
- req, err := http.NewRequest("POST", "/v1.19/networks", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusCreated {
- t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
- }
- if len(rsp.body) == 0 {
- t.Fatalf("Empty response body")
- }
- var nid string
- err = json.Unmarshal(rsp.body, &nid)
- if err != nil {
- t.Fatal(err)
- }
- // Query networks collection
- req, err = http.NewRequest("GET", "/v1.19/networks?name=", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- var list []*networkResource
- err = json.Unmarshal(rsp.body, &list)
- if err != nil {
- t.Fatal(err)
- }
- if len(list) != 0 {
- t.Fatalf("Expected empty list. Got %v", list)
- }
- req, err = http.NewRequest("GET", "/v1.19/networks", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- b0 := make([]byte, len(rsp.body))
- copy(b0, rsp.body)
- req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- if !bytes.Equal(b0, rsp.body) {
- t.Fatalf("Expected same body from GET /networks and GET /networks?name=<nw> when only network <nw> exist.")
- }
- // Query network by name
- req, err = http.NewRequest("GET", "/v1.19/networks?name=culo", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &list)
- if err != nil {
- t.Fatal(err)
- }
- if len(list) != 0 {
- t.Fatalf("Expected empty list. Got %v", list)
- }
- req, err = http.NewRequest("GET", "/v1.19/networks?name=network-fiftyfive", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &list)
- if err != nil {
- t.Fatal(err)
- }
- if len(list) == 0 {
- t.Fatalf("Expected non empty list")
- }
- if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
- t.Fatalf("Incongruent resource found: %v", list[0])
- }
- // Query network by partial id
- chars := []byte(nid)
- partial := string(chars[0 : len(chars)/2])
- req, err = http.NewRequest("GET", "/v1.19/networks?partial-id="+partial, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &list)
- if err != nil {
- t.Fatal(err)
- }
- if len(list) == 0 {
- t.Fatalf("Expected non empty list")
- }
- if list[0].Name != "network-fiftyfive" || nid != list[0].ID {
- t.Fatalf("Incongruent resource found: %v", list[0])
- }
- // Get network by id
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- var nwr networkResource
- err = json.Unmarshal(rsp.body, &nwr)
- if err != nil {
- t.Fatal(err)
- }
- if nwr.Name != "network-fiftyfive" || nid != nwr.ID {
- t.Fatalf("Incongruent resource found: %v", nwr)
- }
- // Create endpoint
- eb, err := json.Marshal(endpointCreate{Name: "ep-TwentyTwo"})
- if err != nil {
- t.Fatal(err)
- }
- lr = newLocalReader(eb)
- req, err = http.NewRequest("POST", "/v1.19/networks/"+nid+"/endpoints", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusCreated {
- t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
- }
- if len(rsp.body) == 0 {
- t.Fatalf("Empty response body")
- }
- var eid string
- err = json.Unmarshal(rsp.body, &eid)
- if err != nil {
- t.Fatal(err)
- }
- // Query endpoint(s)
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=bla", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- var epList []*endpointResource
- err = json.Unmarshal(rsp.body, &epList)
- if err != nil {
- t.Fatal(err)
- }
- if len(epList) != 0 {
- t.Fatalf("Expected empty list. Got %v", epList)
- }
- // Query endpoint by name
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?name=ep-TwentyTwo", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &epList)
- if err != nil {
- t.Fatal(err)
- }
- if len(epList) == 0 {
- t.Fatalf("Empty response body")
- }
- if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
- t.Fatalf("Incongruent resource found: %v", epList[0])
- }
- // Query endpoint by partial id
- chars = []byte(eid)
- partial = string(chars[0 : len(chars)/2])
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints?partial-id="+partial, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &epList)
- if err != nil {
- t.Fatal(err)
- }
- if len(epList) == 0 {
- t.Fatalf("Empty response body")
- }
- if epList[0].Name != "ep-TwentyTwo" || eid != epList[0].ID {
- t.Fatalf("Incongruent resource found: %v", epList[0])
- }
- // Get endpoint by id
- req, err = http.NewRequest("GET", "/v1.19/networks/"+nid+"/endpoints/"+eid, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- var epr endpointResource
- err = json.Unmarshal(rsp.body, &epr)
- if err != nil {
- t.Fatal(err)
- }
- if epr.Name != "ep-TwentyTwo" || epr.ID != eid {
- t.Fatalf("Incongruent resource found: %v", epr)
- }
- // Store two container ids and one partial ids
- cid1 := "container10010000000"
- cid2 := "container20010000000"
- chars = []byte(cid1)
- cpid1 := string(chars[0 : len(chars)/2])
- // Create sandboxes
- sb1, err := json.Marshal(sandboxCreate{ContainerID: cid1})
- if err != nil {
- t.Fatal(err)
- }
- lr = newLocalReader(sb1)
- req, err = http.NewRequest("POST", "/v5.22/sandboxes", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusCreated {
- t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
- }
- if len(rsp.body) == 0 {
- t.Fatalf("Empty response body")
- }
- // Get sandbox id and partial id
- var sid1 string
- err = json.Unmarshal(rsp.body, &sid1)
- if err != nil {
- t.Fatal(err)
- }
- sb2, err := json.Marshal(sandboxCreate{ContainerID: cid2})
- if err != nil {
- t.Fatal(err)
- }
- lr = newLocalReader(sb2)
- req, err = http.NewRequest("POST", "/v5.22/sandboxes", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusCreated {
- t.Fatalf("Unexpectded status code. Expected (%d). Got (%d): %s.", http.StatusCreated, rsp.statusCode, string(rsp.body))
- }
- if len(rsp.body) == 0 {
- t.Fatalf("Empty response body")
- }
- // Get sandbox id and partial id
- var sid2 string
- err = json.Unmarshal(rsp.body, &sid2)
- if err != nil {
- t.Fatal(err)
- }
- chars = []byte(sid2)
- spid2 := string(chars[0 : len(chars)/2])
- // Query sandboxes
- req, err = http.NewRequest("GET", "/sandboxes", nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Expected StatusOK. Got (%d): %s", rsp.statusCode, rsp.body)
- }
- var sbList []*sandboxResource
- err = json.Unmarshal(rsp.body, &sbList)
- if err != nil {
- t.Fatal(err)
- }
- if len(sbList) != 2 {
- t.Fatalf("Expected 2 elements in list. Got %v", sbList)
- }
- // Get sandbox by id
- req, err = http.NewRequest("GET", "/sandboxes/"+sid1, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- var sbr sandboxResource
- err = json.Unmarshal(rsp.body, &sbr)
- if err != nil {
- t.Fatal(err)
- }
- if sbr.ContainerID != cid1 {
- t.Fatalf("Incongruent resource found: %v", sbr)
- }
- // Query sandbox by partial sandbox id
- req, err = http.NewRequest("GET", "/sandboxes?partial-id="+spid2, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &sbList)
- if err != nil {
- t.Fatal(err)
- }
- if len(sbList) == 0 {
- t.Fatalf("Empty response body")
- }
- if sbList[0].ID != sid2 {
- t.Fatalf("Incongruent resource found: %v", sbList[0])
- }
- // Query sandbox by container id
- req, err = http.NewRequest("GET", "/sandboxes?container-id="+cid2, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &sbList)
- if err != nil {
- t.Fatal(err)
- }
- if len(sbList) == 0 {
- t.Fatalf("Empty response body")
- }
- if sbList[0].ContainerID != cid2 {
- t.Fatalf("Incongruent resource found: %v", sbList[0])
- }
- // Query sandbox by partial container id
- req, err = http.NewRequest("GET", "/sandboxes?partial-container-id="+cpid1, nil)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if rsp.statusCode != http.StatusOK {
- t.Fatalf("Unexpectded failure: (%d): %s", rsp.statusCode, rsp.body)
- }
- err = json.Unmarshal(rsp.body, &sbList)
- if err != nil {
- t.Fatal(err)
- }
- if len(sbList) == 0 {
- t.Fatalf("Empty response body")
- }
- if sbList[0].ContainerID != cid1 {
- t.Fatalf("Incongruent resource found: %v", sbList[0])
- }
- }
- func TestEndToEndErrorMessage(t *testing.T) {
- defer testutils.SetupTestOSContext(t)()
- rsp := newWriter()
- // Cleanup local datastore file
- os.Remove(datastore.DefaultScopes("")[datastore.LocalScope].Client.Address)
- c, err := libnetwork.New()
- if err != nil {
- t.Fatal(err)
- }
- defer c.Stop()
- handleRequest := NewHTTPHandler(c)
- body := []byte{}
- lr := newLocalReader(body)
- req, err := http.NewRequest("POST", "/v1.19/networks", lr)
- if err != nil {
- t.Fatal(err)
- }
- handleRequest(rsp, req)
- if len(rsp.body) == 0 {
- t.Fatalf("Empty response body.")
- }
- empty := []byte("\"\"")
- if bytes.Equal(empty, bytes.TrimSpace(rsp.body)) {
- t.Fatalf("Empty response error message.")
- }
- }
- type bre struct{}
- func (b *bre) Error() string {
- return "I am a bad request error"
- }
- func (b *bre) BadRequest() {}
- type nfe struct{}
- func (n *nfe) Error() string {
- return "I am a not found error"
- }
- func (n *nfe) NotFound() {}
- type forb struct{}
- func (f *forb) Error() string {
- return "I am a bad request error"
- }
- func (f *forb) Forbidden() {}
- type notimpl struct{}
- func (nip *notimpl) Error() string {
- return "I am a not implemented error"
- }
- func (nip *notimpl) NotImplemented() {}
- type inter struct{}
- func (it *inter) Error() string {
- return "I am a internal error"
- }
- func (it *inter) Internal() {}
- type tout struct{}
- func (to *tout) Error() string {
- return "I am a timeout error"
- }
- func (to *tout) Timeout() {}
- type noserv struct{}
- func (nos *noserv) Error() string {
- return "I am a no service error"
- }
- func (nos *noserv) NoService() {}
- type notclassified struct{}
- func (noc *notclassified) Error() string {
- return "I am a non classified error"
- }
- func TestErrorConversion(t *testing.T) {
- if convertNetworkError(new(bre)).StatusCode != http.StatusBadRequest {
- t.Fatalf("Failed to recognize BadRequest error")
- }
- if convertNetworkError(new(nfe)).StatusCode != http.StatusNotFound {
- t.Fatalf("Failed to recognize NotFound error")
- }
- if convertNetworkError(new(forb)).StatusCode != http.StatusForbidden {
- t.Fatalf("Failed to recognize Forbidden error")
- }
- if convertNetworkError(new(notimpl)).StatusCode != http.StatusNotImplemented {
- t.Fatalf("Failed to recognize NotImplemented error")
- }
- if convertNetworkError(new(inter)).StatusCode != http.StatusInternalServerError {
- t.Fatalf("Failed to recognize Internal error")
- }
- if convertNetworkError(new(tout)).StatusCode != http.StatusRequestTimeout {
- t.Fatalf("Failed to recognize Timeout error")
- }
- if convertNetworkError(new(noserv)).StatusCode != http.StatusServiceUnavailable {
- t.Fatalf("Failed to recognize No Service error")
- }
- if convertNetworkError(new(notclassified)).StatusCode != http.StatusInternalServerError {
- t.Fatalf("Failed to recognize not classified error as Internal error")
- }
- }
- func TestFieldRegex(t *testing.T) {
- pr := regexp.MustCompile(regex)
- qr := regexp.MustCompile(`^` + qregx + `$`) // mux compiles it like this
- if pr.MatchString("") {
- t.Fatalf("Unexpected match")
- }
- if !qr.MatchString("") {
- t.Fatalf("Unexpected match failure")
- }
- if pr.MatchString(":") {
- t.Fatalf("Unexpected match")
- }
- if qr.MatchString(":") {
- t.Fatalf("Unexpected match")
- }
- if pr.MatchString(".") {
- t.Fatalf("Unexpected match")
- }
- if qr.MatchString(".") {
- t.Fatalf("Unexpected match")
- }
- }
|