storetesting

package
v5.12.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 9, 2021 License: AGPL-3.0 Imports: 27 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var Charms = testing.NewRepo("charm-repo", "quantal")

Charms holds the testing charm repository.

View Source
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},
	},
}
View Source
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

func AssertEntity(c *gc.C, db *mgo.Collection, expect *mongodoc.Entity)

AssertEntity checks that db contains an entity that matches expect.

func JSONReader

func JSONReader(v interface{}) io.Reader

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

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.

func NewBlob

func NewBlob(files []File) *Blob

NewBlob returns a blob that holds the given files.

func (*Blob) ArchiveTo

func (b *Blob) ArchiveTo(w io.Writer) error

ArchiveTo implements charmstore.ArchiverTo.ArchiveTo.

func (*Blob) Bytes

func (b *Blob) Bytes() []byte

Bytes returns the contents of the blob.

func (*Blob) Size

func (b *Blob) Size() int64

Size returns the size of the blob.

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.

func NewBundle

func NewBundle(data *charm.BundleData) *Bundle

NewBundle returns a bundle implementation that contains the given bundle data.

func NewBundleWithOverlaysFlag added in v5.7.0

func NewBundleWithOverlaysFlag(data *charm.BundleData, containsOverlays bool) *Bundle

NewBundleWithOverlaysFlag returns a bundle implementation that contains the given bundle data and sets its ContainsOverlays flag to the specified value.

func (*Bundle) ContainsOverlays added in v5.7.0

func (b *Bundle) ContainsOverlays() bool

ContainsOverlays implements charm.Bundle.

func (*Bundle) Data

func (b *Bundle) Data() *charm.BundleData

Data implements charm.Bundle.Data.

func (*Bundle) ReadMe

func (b *Bundle) ReadMe() string

ReadMe implements charm.Bundle.ReadMe.

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) ArchiveTo

func (c *Charm) ArchiveTo(w io.Writer) error

ArchiveTo implements charmstore.ArchiverTo.

func (*Charm) Bytes

func (c *Charm) Bytes() []byte

Bytes returns the contents of the charm's archive.

func (*Charm) Config

func (c *Charm) Config() *charm.Config

Config implements charm.Charm.Config.

func (*Charm) Meta

func (c *Charm) Meta() *charm.Meta

Meta implements charm.Charm.Meta.

func (*Charm) Metrics

func (c *Charm) Metrics() *charm.Metrics

Metrics implements charm.Charm.Metrics.

func (*Charm) Revision

func (c *Charm) Revision() int

Revision implements charm.Charm.Revision.

func (*Charm) Size

func (c *Charm) Size() int64

Size returns the size of the charm's archive blob.

func (*Charm) WithMetrics

func (c *Charm) WithMetrics(metrics *charm.Metrics) *Charm

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 File

type File struct {
	Name string
	Data []byte
}

File represents a file which will be added to a new blob.

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

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL