func (s *txnSuite) SetUpTest(c *gc.C) { s.BaseSuite.SetUpTest(c) s.MgoSuite.SetUpTest(c) db := s.Session.DB("juju") s.collection = db.C("test") s.txnRunner = statetxn.NewRunner(txn.NewRunner(s.collection)) }
func (s *managedStorageSuite) SetUpTest(c *gc.C) { s.BaseSuite.SetUpTest(c) s.MgoSuite.SetUpTest(c) s.db = s.Session.DB("juju") s.txnRunner = statetxn.NewRunner(txn.NewRunner(s.db.C("txns"))) s.resourceStorage = storage.NewGridFS("storage", "test", s.Session) s.managedStorage = storage.NewManagedStorage(s.db, s.txnRunner, s.resourceStorage) }
func (s *resourceCatalogSuite) SetUpTest(c *gc.C) { s.BaseSuite.SetUpTest(c) s.MgoSuite.SetUpTest(c) db := s.Session.DB("juju") s.collection = db.C("storedResources") s.txnRunner = statetxn.NewRunner(txn.NewRunner(db.C("resourceTxns"))) s.rCatalog = storage.NewResourceCatalog(s.collection, s.txnRunner) }
func (s *benchmarkSuite) BenchmarkManagedStorageCreate(c *gc.C) { db := s.Session.DB("a-database") txnRunner := jujuTxn.NewRunner(txn.NewRunner(db.C("txns"))) rstore := storage.NewGridFS(db.Name, "prefix", s.Session) store := storage.NewManagedStorage(db, txnRunner, rstore) c.ResetTimer() const fileSize = 30 * 1024 for i := 0; i < c.N; i++ { src := newDataSource(int64(i), fileSize) err := store.PutForEnvironment("env-uuid", fmt.Sprintf("file%d", i), src, fileSize) c.Assert(err, gc.IsNil) } }
func newState(session *mgo.Session, info *Info, policy Policy) (*State, error) { db := session.DB("juju") pdb := session.DB("presence") admin := session.DB("admin") if info.Tag != "" { if err := db.Login(info.Tag, info.Password); err != nil { return nil, maybeUnauthorized(err, fmt.Sprintf("cannot log in to juju database as %q", info.Tag)) } if err := pdb.Login(info.Tag, info.Password); err != nil { return nil, maybeUnauthorized(err, fmt.Sprintf("cannot log in to presence database as %q", info.Tag)) } if err := admin.Login(info.Tag, info.Password); err != nil { return nil, maybeUnauthorized(err, fmt.Sprintf("cannot log in to admin database as %q", info.Tag)) } } else if info.Password != "" { if err := admin.Login(AdminUser, info.Password); err != nil { return nil, maybeUnauthorized(err, "cannot log in to admin database") } } st := &State{ info: info, policy: policy, db: db, environments: db.C("environments"), charms: db.C("charms"), machines: db.C("machines"), containerRefs: db.C("containerRefs"), instanceData: db.C("instanceData"), relations: db.C("relations"), relationScopes: db.C("relationscopes"), services: db.C("services"), requestedNetworks: db.C("requestednetworks"), networks: db.C("networks"), networkInterfaces: db.C("networkinterfaces"), minUnits: db.C("minunits"), settings: db.C("settings"), settingsrefs: db.C("settingsrefs"), constraints: db.C("constraints"), units: db.C("units"), actions: db.C("actions"), actionresults: db.C("actionresults"), users: db.C("users"), presence: pdb.C("presence"), cleanups: db.C("cleanups"), annotations: db.C("annotations"), statuses: db.C("statuses"), stateServers: db.C("stateServers"), } log := db.C("txns.log") logInfo := mgo.CollectionInfo{Capped: true, MaxBytes: logSize} // The lack of error code for this error was reported upstream: // https://jira.klmongodb.org/browse/SERVER-6992 err := log.Create(&logInfo) if err != nil && err.Error() != "collection already exists" { return nil, maybeUnauthorized(err, "cannot create log collection") } mgoRunner := txn.NewRunner(db.C("txns")) mgoRunner.ChangeLog(db.C("txns.log")) st.transactionRunner = statetxn.NewRunner(mgoRunner) st.watcher = watcher.New(db.C("txns.log")) st.pwatcher = presence.NewWatcher(pdb.C("presence")) for _, item := range indexes { index := mgo.Index{Key: item.key, Unique: item.unique} if err := db.C(item.collection).EnsureIndex(index); err != nil { return nil, fmt.Errorf("cannot create database index: %v", err) } } // TODO(rog) delete this when we can assume there are no // pre-1.18 environments running. if err := st.createStateServersDoc(); err != nil { return nil, fmt.Errorf("cannot create state servers document: %v", err) } if err := st.createAPIAddressesDoc(); err != nil { return nil, fmt.Errorf("cannot create API addresses document: %v", err) } if err := st.createStateServingInfoDoc(); err != nil { return nil, fmt.Errorf("cannot create state serving info document: %v", err) } return st, nil }