Documentation ¶
Index ¶
- Variables
- func AssertBaseEntity(c *gc.C, db *mgo.Collection, expect *mongodoc.BaseEntity)
- func AssertEntity(c *gc.C, db *mgo.Collection, expect *mongodoc.Entity)
- func JSONReader(v interface{}) io.Reader
- func MetaWithCategories(m *charm.Meta, categories ...string) *charm.Meta
- func MetaWithDockerResources(m *charm.Meta, resources ...string) *charm.Meta
- func MetaWithResources(m *charm.Meta, resources ...string) *charm.Meta
- func MetaWithSupportedSeries(m *charm.Meta, series ...string) *charm.Meta
- func MetaWithTags(m *charm.Meta, tags ...string) *charm.Meta
- func MongoJSEnabled() bool
- func MustMarshalJSON(v interface{}) []byte
- func NormalizeBaseEntity(be *mongodoc.BaseEntity) *mongodoc.BaseEntity
- func RelationMeta(relations ...string) *charm.Meta
- func ResolvedURLWithSeries(rurl *router.ResolvedURL, series string) *router.ResolvedURL
- func ResolvedURLs(es []SearchEntity, expand bool) []*router.ResolvedURL
- func SortResolvedURLsBySeries(urls []*router.ResolvedURL, desc bool) []*router.ResolvedURL
- type BaseEntityBuilder
- type Blob
- type Bundle
- type Charm
- func (c *Charm) Actions() *charm.Actions
- func (c *Charm) ArchiveTo(w io.Writer) error
- func (c *Charm) Bytes() []byte
- func (c *Charm) Config() *charm.Config
- func (c *Charm) Meta() *charm.Meta
- func (c *Charm) Metrics() *charm.Metrics
- func (c *Charm) Revision() int
- func (c *Charm) Size() int64
- func (c *Charm) WithMetrics(metrics *charm.Metrics) *Charm
- type ElasticSearchSuite
- func (s *ElasticSearchSuite) LoadESConfig(index string, settings, mapping interface{}) error
- func (s *ElasticSearchSuite) NewIndex(c *gc.C) string
- func (s *ElasticSearchSuite) SetUpSuite(c *gc.C)
- func (s *ElasticSearchSuite) SetUpTest(c *gc.C)
- func (s *ElasticSearchSuite) TearDownSuite(c *gc.C)
- func (s *ElasticSearchSuite) TearDownTest(c *gc.C)
- type EntityBuilder
- type File
- type IsolatedMgoESSuite
- type SearchEntity
Constants ¶
This section is empty.
Variables ¶
var Charms = testing.NewRepo("charm-repo", "quantal")
Charms holds the testing charm repository.
var SearchEntities = map[string]SearchEntity{ "wordpress": { URL: charm.MustParseURL("cs:~charmers/" + SearchSeries[0] + "/wordpress-23"), PromulgatedRevision: 23, Charm: NewCharm(&charm.Meta{ Description: "blog", Provides: map[string]charm.Relation{ "url": { Name: "url", Interface: "http", Scope: charm.ScopeGlobal, }, "monitoring-port": { Name: "monitoring-port", Interface: "monitoring", Scope: charm.ScopeContainer, }, }, Requires: map[string]charm.Relation{ "mysql": { Name: "mysql", Interface: "mysql", Scope: charm.ScopeGlobal, }, "cache": { Name: "cache", Interface: "varnish", Scope: charm.ScopeGlobal, }, }, Categories: []string{"wordpress", "wordpressCAT"}, Tags: []string{"wordpressTAG"}, }), ACL: []string{params.Everyone}, }, "mysql": { URL: charm.MustParseURL("cs:~openstack-charmers/" + SearchSeries[2] + "/mysql-7"), PromulgatedRevision: 7, Charm: NewCharm(&charm.Meta{ Summary: "Database Engine", Description: "database", Provides: map[string]charm.Relation{ "mysql": { Name: "mysql", Interface: "mysql", Scope: charm.ScopeGlobal, }, }, Categories: []string{"mysql"}, Tags: []string{"mysqlTAG", "bar"}, }), ACL: []string{params.Everyone}, Downloads: 3, }, "varnish": { URL: charm.MustParseURL("cs:~foo/" + SearchSeries[2] + "/varnish-1"), PromulgatedRevision: -1, Charm: NewCharm(&charm.Meta{ Summary: "Database Engine", Description: "database", Categories: []string{"varnish"}, Tags: []string{"varnishTAG"}, }), ACL: []string{params.Everyone}, Downloads: 5, }, "riak": { URL: charm.MustParseURL("cs:~charmers/" + SearchSeries[2] + "/riak-67"), PromulgatedRevision: 67, Charm: NewCharm(&charm.Meta{ Categories: []string{"riak"}, Tags: []string{"riakTAG"}, }), ACL: []string{"charmers"}, }, "wordpress-simple": { URL: charm.MustParseURL("cs:~charmers/bundle/wordpress-simple-4"), PromulgatedRevision: 4, Bundle: NewBundle(&charm.BundleData{ Applications: map[string]*charm.ApplicationSpec{ "wordpress": { Charm: "wordpress", NumUnits: 1, }, }, Tags: []string{"wordpress"}, }), ACL: []string{params.Everyone}, Downloads: 1, }, "squid-forwardproxy": { URL: charm.MustParseURL("cs:~charmers/" + SearchSeries[2] + "/squid-forwardproxy-3"), PromulgatedRevision: 3, Charm: NewCharm(&charm.Meta{}), ACL: []string{params.Everyone}, Downloads: 2, }, "cloud-controller-worker-v2": { URL: charm.MustParseURL("cs:~cf-charmers/" + SearchSeries[1] + "/cloud-controller-worker-v2-7"), PromulgatedRevision: -1, Charm: NewCharm(&charm.Meta{}), ACL: []string{params.Everyone}, Downloads: 4, }, "multi-series": { URL: charm.MustParseURL("cs:~charmers/multi-series-0"), PromulgatedRevision: 0, Charm: NewCharm(&charm.Meta{ Series: SearchSeries, Provides: map[string]charm.Relation{ "url": { Name: "url", Interface: "http", Scope: charm.ScopeGlobal, }, "monitoring-port": { Name: "monitoring-port", Interface: "monitoring", Scope: charm.ScopeContainer, }, }, Requires: map[string]charm.Relation{ "mysql": { Name: "mysql", Interface: "mysql", Scope: charm.ScopeGlobal, }, "cache": { Name: "cache", Interface: "varnish", Scope: charm.ScopeGlobal, }, }, Categories: []string{"multi-series", "multi-seriesCAT"}, Tags: []string{"multi-seriesTAG"}, }), ACL: []string{params.Everyone}, }, }
var SearchSeries = func() []string { var ss []string for k, v := range series.Series { if v.Distribution != series.Ubuntu || !v.SearchIndex { continue } ss = append(ss, k) } sort.Slice(ss, func(i, j int) bool { return series.Series[ss[i]].SearchBoost > series.Series[ss[j]].SearchBoost }) return ss }()
SearchSeries contains the list of charm series that will be indexed in the search in descending order of preference.
Functions ¶
func AssertBaseEntity ¶
func AssertBaseEntity(c *gc.C, db *mgo.Collection, expect *mongodoc.BaseEntity)
AssertBaseEntity checks that db contains a base entity that matches expect.
func AssertEntity ¶
AssertEntity checks that db contains an entity that matches expect.
func JSONReader ¶
JSONReader creates an io.Reader which can read the Marshalled value of v.
func MetaWithCategories ¶
func MetaWithCategories(m *charm.Meta, categories ...string) *charm.Meta
MetaWithCategories returns m with Categories set to categories. If m is nil, new(charm.Meta) will be used instead.
func MetaWithDockerResources ¶ added in v5.1.1
func MetaWithDockerResources(m *charm.Meta, resources ...string) *charm.Meta
MetaWithDockerResources returns m with Resources set to a set of docker resources with the given names. If m is nil, new(charm.Meta) will be used instead.
The description of the resources are derived from the resource name by adding " description" suffix respectively.
func MetaWithResources ¶
func MetaWithResources(m *charm.Meta, resources ...string) *charm.Meta
MetaWithResources returns m with Resources set to a set of resources with the given names. If m is nil, new(charm.Meta) will be used instead.
The path and description of the resources are derived from the resource name by adding a "-file" and a " description" suffix respectively.
func MetaWithSupportedSeries ¶
func MetaWithSupportedSeries(m *charm.Meta, series ...string) *charm.Meta
MetaWithSupportedSeries returns m with Series set to series. If m is nil, new(charm.Meta) will be used instead.
func MetaWithTags ¶
func MetaWithTags(m *charm.Meta, tags ...string) *charm.Meta
MetaWithTags returns m with Tags set to tags. If m is nil, new(charm.Meta) will be used instead.
func MongoJSEnabled ¶
func MongoJSEnabled() bool
MongoJSEnabled reports whether testing code should run tests that rely on JavaScript inside MongoDB.
func MustMarshalJSON ¶
func MustMarshalJSON(v interface{}) []byte
MustMarshalJSON marshals the specified value using json.Marshal and returns the corresponding byte slice. If there is an error marshalling the value then MustMarshalJSON will panic.
func NormalizeBaseEntity ¶
func NormalizeBaseEntity(be *mongodoc.BaseEntity) *mongodoc.BaseEntity
NormalizeBaseEntity modifies a base entity so that it can be compared with another normalized base entity using jc.DeepEquals.
func RelationMeta ¶
func RelationMeta(relations ...string) *charm.Meta
RelationMeta returns charm metadata for a charm with the given relations, where each relation is specified as a white-space-separated triple:
role name interface
where role specifies the role of the interface (provides or requires), name holds the relation name and interface holds the interface relation type.
func ResolvedURLWithSeries ¶ added in v5.6.7
func ResolvedURLWithSeries(rurl *router.ResolvedURL, series string) *router.ResolvedURL
ResolvedURLWithSeries creates a copy of the given ResolvedURL with the given series.
func ResolvedURLs ¶ added in v5.6.7
func ResolvedURLs(es []SearchEntity, expand bool) []*router.ResolvedURL
ResolvedURLs creates a list of ResolvedURLs for the given SearchEntities. If expand is true then all the URLs will be expanded to include all possible series. This if for v4 compatibility.
func SortResolvedURLsBySeries ¶ added in v5.6.7
func SortResolvedURLsBySeries(urls []*router.ResolvedURL, desc bool) []*router.ResolvedURL
SortResolvedURLsBySeries sorts the given slice of ResolvedURLs in series order.
Types ¶
type BaseEntityBuilder ¶
type BaseEntityBuilder struct {
// contains filtered or unexported fields
}
BaseEntityBuilder provides a convenient way to describe a mongodoc.BaseEntity for tests that is correctly formed and contains the desired information.
func NewBaseEntity ¶
func NewBaseEntity(url string) BaseEntityBuilder
NewBaseEntity creates a new BaseEntityBuilder for the provided URL.
func (BaseEntityBuilder) Build ¶
func (b BaseEntityBuilder) Build() *mongodoc.BaseEntity
Build creates a mongodoc.BaseEntity from the BaseEntityBuilder.
func (BaseEntityBuilder) WithACLs ¶
func (b BaseEntityBuilder) WithACLs(channel params.Channel, acls mongodoc.ACL) BaseEntityBuilder
WithACLs sets the ACLs field on the BaseEntity.
func (BaseEntityBuilder) WithPromulgated ¶
func (b BaseEntityBuilder) WithPromulgated(promulgated bool) BaseEntityBuilder
WithPromulgated sets the promulgated flag on the BaseEntity.
type Blob ¶
type Blob struct {
// contains filtered or unexported fields
}
Blob represents a blob of data - a zip archive. Since it implements charmstore.ArchiverTo, it can be used to add charms or bundles with specific contents to the charm store.
type Bundle ¶
type Bundle struct { *Blob // contains filtered or unexported fields }
Bundle implements an in-memory charm.Bundle that can be archived.
Note that because it implements charmstore.ArchiverTo, it can be used as an argument to charmstore.Store.AddBundleWithArchive.
type Charm ¶
type Charm struct {
// contains filtered or unexported fields
}
Charm implements an in-memory charm.Charm that can be archived.
Note that because it implements charmstore.ArchiverTo, it can be used as an argument to charmstore.Store.AddCharmWithArchive.
func NewCharm ¶
func NewCharm(meta *charm.Meta) *Charm
NewCharm returns a charm implementation that contains the given charm metadata. All charm.Charm methods other than Meta will return empty values. If meta is nil, new(charm.Meta) will be used.
func (*Charm) Actions ¶
func (c *Charm) Actions() *charm.Actions
Actions implements charm.Charm.Actions.
func (*Charm) Metrics ¶
func (c *Charm) Metrics() *charm.Metrics
Metrics implements charm.Charm.Metrics.
func (*Charm) WithMetrics ¶
type ElasticSearchSuite ¶
type ElasticSearchSuite struct { ES *elasticsearch.Database TestIndex string // contains filtered or unexported fields }
ElasticSearchSuite defines a test suite that connects to an elastic-search server. The address of the server depends on the value of the JUJU_TEST_ELASTICSEARCH environment variable, which can be "none" (do not start or connect to a server) or host:port holding the address and port of the server to connect to. If JUJU_TEST_ELASTICSEARCH is not specified then localhost:9200 will be used.
func (*ElasticSearchSuite) LoadESConfig ¶
func (s *ElasticSearchSuite) LoadESConfig(index string, settings, mapping interface{}) error
LoadESConfig loads a canned test configuration to the specified index
func (*ElasticSearchSuite) NewIndex ¶
func (s *ElasticSearchSuite) NewIndex(c *gc.C) string
NewIndex creates a new index name and ensures that it will be cleaned up at end of the test.
func (*ElasticSearchSuite) SetUpSuite ¶
func (s *ElasticSearchSuite) SetUpSuite(c *gc.C)
func (*ElasticSearchSuite) SetUpTest ¶
func (s *ElasticSearchSuite) SetUpTest(c *gc.C)
func (*ElasticSearchSuite) TearDownSuite ¶
func (s *ElasticSearchSuite) TearDownSuite(c *gc.C)
func (*ElasticSearchSuite) TearDownTest ¶
func (s *ElasticSearchSuite) TearDownTest(c *gc.C)
type EntityBuilder ¶
type EntityBuilder struct {
// contains filtered or unexported fields
}
EntityBuilder provides a convenient way to describe a mongodoc.Entity for tests that is correctly formed and contains the desired information.
func NewEntity ¶
func NewEntity(url string) EntityBuilder
NewEntity creates a new EntityBuilder for the provided URL.
func (EntityBuilder) Build ¶
func (b EntityBuilder) Build() *mongodoc.Entity
Build creates a mongodoc.Entity from the EntityBuilder.
func (EntityBuilder) WithPromulgatedURL ¶
func (b EntityBuilder) WithPromulgatedURL(url string) EntityBuilder
WithPromulgatedURL sets the PromulgatedURL and PromulgatedRevision of the entity being built.
type IsolatedMgoESSuite ¶
type IsolatedMgoESSuite struct { jujutesting.IsolatedMgoSuite ElasticSearchSuite }
func (*IsolatedMgoESSuite) SetUpSuite ¶
func (s *IsolatedMgoESSuite) SetUpSuite(c *gc.C)
func (*IsolatedMgoESSuite) SetUpTest ¶
func (s *IsolatedMgoESSuite) SetUpTest(c *gc.C)
func (*IsolatedMgoESSuite) TearDownSuite ¶
func (s *IsolatedMgoESSuite) TearDownSuite(c *gc.C)
func (*IsolatedMgoESSuite) TearDownTest ¶
func (s *IsolatedMgoESSuite) TearDownTest(c *gc.C)
type SearchEntity ¶ added in v5.6.7
type SearchEntity struct { URL *charm.URL PromulgatedRevision int SupportedSeries []string Charm *Charm Bundle *Bundle ACL []string Downloads int }
A SearchEntity is an entity that is used in search tests.
func SortBySeries ¶ added in v5.6.7
func SortBySeries(es []SearchEntity, desc bool) []SearchEntity
SortBySeries sorts the given slice of SearchEntities by series name and returns the slice.
func (SearchEntity) Entity ¶ added in v5.6.7
func (e SearchEntity) Entity() *mongodoc.Entity
func (SearchEntity) ResolvedURL ¶ added in v5.6.7
func (e SearchEntity) ResolvedURL() *router.ResolvedURL