PluginResourceTypeView metaView = metaStoreService.getResourceTypeView(account, type); if (!metaView.exists(name, version)) { metaView.add(meta);
metaStoreService.getResourceTypeView(account, resourceType).add(resourceMeta);
@Test public void testGetNumResources() throws Exception { PluginMetaStoreService service = getPluginResourceMetaStoreService(); // for account1 write 6 resources (7 but one is deleted) in all different states service.getResourceTypeView(account1, type1).add(new ResourceMeta("r1", 1, ResourceStatus.ACTIVE)); service.getResourceTypeView(account1, type1).add(new ResourceMeta("r1", 2, ResourceStatus.INACTIVE)); service.getResourceTypeView(account1, type1).add(new ResourceMeta("r2", 1, ResourceStatus.INACTIVE)); service.getResourceTypeView(account1, type1).add(new ResourceMeta("r2", 2, ResourceStatus.STAGED)); service.getResourceTypeView(account1, type2).add(new ResourceMeta("r3", 1, ResourceStatus.RECALLED)); service.getResourceTypeView(account1, type2).add(new ResourceMeta("r3", 2, ResourceStatus.STAGED)); service.getResourceTypeView(account1, type2).add(new ResourceMeta("r3", 3, ResourceStatus.STAGED)); service.getResourceTypeView(account1, type2).delete("r3", 3); Assert.assertEquals(6, service.getAccountView(account1).numResources()); // account 2 should have nothing Assert.assertEquals(0, service.getAccountView(account2).numResources()); }
view.add(meta);
ResourceMeta apache2 = new ResourceMeta("apache", 2, ResourceStatus.RECALLED); view1.add(hadoop1); view1.add(hadoop2); view1.add(hadoop3); view1.add(mysql1); view1.add(mysql2); view1.add(apache1); view1.add(apache2); ResourceMeta sue1 = new ResourceMeta("sue", 1, ResourceStatus.RECALLED); view2.add(bob1); view2.add(bob2); view2.add(sally1); view2.add(sue1);
ResourceMeta meta1 = new ResourceMeta("name1", 3, ResourceStatus.ACTIVE); ResourceMeta meta2 = new ResourceMeta("name2", 2, ResourceStatus.INACTIVE); metaStoreService.getResourceTypeView(Account.SUPERADMIN, type1).add(meta1); metaStoreService.getResourceTypeView(Account.SUPERADMIN, type1).add(meta2); writePluginResource(Account.SUPERADMIN, type1, meta1.getName(), meta1.getVersion(), "meta1 contents"); writePluginResource(Account.SUPERADMIN, type1, meta2.getName(), meta2.getVersion(), "meta2 contents");
@Test public void testStageOnNothingIsNoOp() throws Exception { PluginMetaStoreService service = getPluginResourceMetaStoreService(); PluginResourceTypeView view = service.getResourceTypeView(account1, type1); ResourceMeta hadoop = new ResourceMeta("hadoop", 1, ResourceStatus.STAGED); view.add(hadoop); // if we stage a non-existent version, the current staged version should not be affected view.stage(hadoop.getName(), hadoop.getVersion() + 1); Assert.assertEquals(ResourceStatus.STAGED, view.get(hadoop.getName(), hadoop.getVersion()).getStatus()); }
@Test public void testWriteDeleteExistsGetWithinAccount() throws Exception { PluginMetaStoreService service = getPluginResourceMetaStoreService(); PluginResourceTypeView view = service.getResourceTypeView(account1, type1); String name = "name"; int version = 1; ResourceMeta meta = new ResourceMeta(name, version); view.add(meta); Assert.assertTrue(view.exists(name, version)); Assert.assertEquals(meta, view.get(name, version)); view.delete(name, version); Assert.assertFalse(view.exists(name, version)); Assert.assertNull(view.get(name, version)); }
@Test public void testAccountSeparation() throws Exception { PluginMetaStoreService service = getPluginResourceMetaStoreService(); PluginResourceTypeView view1 = service.getResourceTypeView(account1, type1); PluginResourceTypeView view2 = service.getResourceTypeView(account2, type1); String name = "name"; int version = 1; ResourceMeta meta = new ResourceMeta(name, version); view1.add(meta); Assert.assertTrue(view1.exists(name, version)); Assert.assertFalse(view2.exists(name, version)); Assert.assertEquals(meta, view1.get(name, version)); Assert.assertNull(view2.get(name, version)); view2.add(meta); Assert.assertTrue(view1.exists(name, version)); Assert.assertTrue(view2.exists(name, version)); Assert.assertEquals(meta, view1.get(name, version)); Assert.assertEquals(meta, view2.get(name, version)); view1.delete(name, version); Assert.assertFalse(view1.exists(name, version)); Assert.assertTrue(view2.exists(name, version)); Assert.assertNull(view1.get(name, version)); Assert.assertEquals(meta, view2.get(name, version)); view2.delete(name, version); Assert.assertFalse(view1.exists(name, version)); Assert.assertFalse(view2.exists(name, version)); Assert.assertNull(view1.get(name, version)); Assert.assertNull(view2.get(name, version)); }
@Test public void testTypeSeparation() throws Exception { PluginMetaStoreService service = getPluginResourceMetaStoreService(); PluginResourceTypeView view1 = service.getResourceTypeView(account1, type1); PluginResourceTypeView view2 = service.getResourceTypeView(account1, type2); String name = "name"; int version = 1; ResourceMeta meta = new ResourceMeta(name, version); view1.add(meta); Assert.assertTrue(view1.exists(name, version)); Assert.assertFalse(view2.exists(name, version)); Assert.assertEquals(meta, view1.get(name, version)); Assert.assertNull(view2.get(name, version)); view2.add(meta); Assert.assertTrue(view1.exists(name, version)); Assert.assertTrue(view2.exists(name, version)); Assert.assertEquals(meta, view1.get(name, version)); Assert.assertEquals(meta, view2.get(name, version)); view1.delete(name, version); Assert.assertFalse(view1.exists(name, version)); Assert.assertTrue(view2.exists(name, version)); Assert.assertNull(view1.get(name, version)); Assert.assertEquals(meta, view2.get(name, version)); view2.delete(name, version); Assert.assertFalse(view1.exists(name, version)); Assert.assertFalse(view2.exists(name, version)); Assert.assertNull(view1.get(name, version)); Assert.assertNull(view2.get(name, version)); }