/** * Tests the authentication of different calls. Currently tests adding a project, updating a * project and getting collections without correct permissions. * * @throws InvalidXmlException * @throws BizInternalException * @throws BizPolicyException * @throws IOException */ @Test public void testAuthentication() throws InvalidXmlException, BizInternalException, BizPolicyException, IOException { Project newProject = new Project(projectOne); newProject.setName("Update"); newProject.setDescription("foo-update"); newProject.setEndDate(new DateTime(2014, 2, 10, 0, 0)); String mimeType = "application/xml"; // Test updating a project without proper permissions MockHttpServletRequest mockReq = newMockRequest("PUT", projectOne.getId(), "test.org", 80); MockHttpServletResponse resp = new MockHttpServletResponse(); ByteArrayOutputStream sink = new ByteArrayOutputStream(); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(pendingUser); controller.handleUpdateProjectRequest( projectOne.getId(), mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); assertEquals(403, resp.getStatus()); // Test adding a project without proper permissions mimeType = "application/xml"; mockReq = newMockRequest("POST", "/project", "test.org", 80); resp = new MockHttpServletResponse(); sink = new ByteArrayOutputStream(); newProject.setId("http://test.org/project/2"); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(pendingUser); controller.handleProjectPostRequest(mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); assertEquals(403, resp.getStatus()); // Test getting the collections for a project without proper permissions mimeType = "application/xml"; mockReq = newMockRequest("GET", projectOne.getId() + "/collections", "test.org", 80); resp = new MockHttpServletResponse(); when(requestUtil.buildRequestUrl(any(HttpServletRequest.class))) .thenReturn(projectOne.getId() + "/collections"); controller.setAuthenticatedUser(pendingUser); controller.handleProjectCollectionsGetRequest( projectOne.getId(), mimeType, null, mockReq, resp); assertNotNull(resp); assertEquals(403, resp.getStatus()); }
/** * Tests that the project metadata is successfully updated. * * @throws InvalidXmlException * @throws ProjectServiceException * @throws BizPolicyException * @throws IOException */ @Test public void testUpdateProject() throws InvalidXmlException, BizInternalException, BizPolicyException, IOException { Project newProject = new Project(projectOne); newProject.setName("Update"); newProject.setDescription("foo-update"); newProject.setEndDate(new DateTime(2014, 2, 10, 0, 0)); final String mimeType = "application/xml"; final MockHttpServletRequest mockReq = newMockRequest("PUT", projectOne.getId(), "test.org", 80); MockHttpServletResponse resp = new MockHttpServletResponse(); ByteArrayOutputStream sink = new ByteArrayOutputStream(); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(admin); controller.handleUpdateProjectRequest( projectOne.getId(), mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); assertEquals(resp.getErrorMessage(), 200, resp.getStatus()); Bop bop = businessObjectBuilder.buildBusinessObjectPackage( new ByteArrayInputStream(resp.getContentAsByteArray())); assertNotNull(bop); Set<Project> projects = bop.getProjects(); assertNotNull(projects); assertEquals(1, projects.size()); Project returnedProject = projects.iterator().next(); assertNotNull(returnedProject); assertTrue(returnedProject.getName().equalsIgnoreCase(newProject.getName())); assertTrue(returnedProject.getDescription().equalsIgnoreCase(newProject.getDescription())); assertTrue(returnedProject.getEndDate().equals(newProject.getEndDate())); assertTrue(returnedProject.getFundingEntity().equalsIgnoreCase(newProject.getFundingEntity())); }
/** * Tests that admin can be added and removed from a project * * @throws IOException * @throws BizPolicyException * @throws ProjectServiceException * @throws InvalidXmlException * @throws BizInternalException */ @Test public void testUpdateProjectAdmin() throws InvalidXmlException, ProjectServiceException, BizPolicyException, IOException, BizInternalException { // Test adding an admin to the project. Project newProject = new Project(projectOne); newProject.addPi(user.getId()); final String mimeType = "application/xml"; final MockHttpServletRequest mockReq = newMockRequest("PUT", projectOne.getId(), "test.org", 80); MockHttpServletResponse resp = new MockHttpServletResponse(); ByteArrayOutputStream sink = new ByteArrayOutputStream(); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(admin); controller.handleUpdateProjectRequest( newProject.getId(), mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); assertEquals(resp.getErrorMessage(), 200, resp.getStatus()); Bop bop = businessObjectBuilder.buildBusinessObjectPackage( new ByteArrayInputStream(resp.getContentAsByteArray())); assertNotNull(bop); Set<Project> projects = bop.getProjects(); assertNotNull(projects); assertEquals(1, projects.size()); Project returnedProject = projects.iterator().next(); assertNotNull(returnedProject); assertEquals(newProject.getPis().size(), returnedProject.getPis().size()); // Test removing an admin from the project. newProject.removePi(user.getId()); resp = new MockHttpServletResponse(); sink = new ByteArrayOutputStream(); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(admin); controller.handleUpdateProjectRequest( newProject.getId(), mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); bop = businessObjectBuilder.buildBusinessObjectPackage( new ByteArrayInputStream(resp.getContentAsByteArray())); assertNotNull(bop); projects = bop.getProjects(); assertNotNull(projects); assertEquals(1, projects.size()); returnedProject = projects.iterator().next(); assertNotNull(returnedProject); assertEquals(newProject.getPis().size(), returnedProject.getPis().size()); }