/** * 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 adding a project through the API * * @throws InvalidXmlException * @throws BizInternalException * @throws BizPolicyException * @throws IOException */ @Test public void testAddProject() throws InvalidXmlException, BizInternalException, BizPolicyException, IOException { Project newProject = new Project(); newProject.setName("Test Project To Add"); newProject.setDescription("adding this project"); List<String> numbers = new ArrayList<String>(); numbers.add("1"); numbers.add("2"); newProject.setNumbers(numbers); newProject.setFundingEntity("The Fed"); newProject.setStartDate(new DateTime(2012, 5, 4, 0, 0)); newProject.setEndDate(new DateTime(2013, 12, 23, 0, 0)); newProject.addPi(admin.getId()); final String mimeType = "application/xml"; final MockHttpServletRequest mockReq = newMockRequest("POST", "/project", "test.org", 80); MockHttpServletResponse resp = new MockHttpServletResponse(); ByteArrayOutputStream sink = new ByteArrayOutputStream(); businessObjectBuilder.buildProject(newProject, sink); controller.setAuthenticatedUser(admin); controller.handleProjectPostRequest(mimeType, sink.toByteArray(), mockReq, resp); assertNotNull(resp); assertEquals(201, 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(); // Have to set the original project id to the id set by the biz service. newProject.setId(returnedProject.getId()); assertEquals(newProject, returnedProject); }