added GroupPermissionITCase

This commit is contained in:
Sebastian Sdorra
2011-02-19 17:59:58 +01:00
parent ca27914cdb
commit bd093ea032
4 changed files with 650 additions and 255 deletions

View File

@@ -35,163 +35,29 @@ package sonia.scm.it;
//~--- non-JDK imports --------------------------------------------------------
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import sonia.scm.user.User;
import sonia.scm.user.UserTestData;
import sonia.scm.util.Util;
import static org.junit.Assert.*;
import static sonia.scm.it.IntegrationTestUtil.*;
//~--- JDK imports ------------------------------------------------------------
import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource;
import java.util.ArrayList;
import java.util.Collection;
/**
*
* @author Sebastian Sdorra
*/
@RunWith(Parameterized.class)
public class UserPermissionITCase
public class UserPermissionITCase extends AbstractPermissionITCaseBase<User>
{
/**
* Constructs ...
*
*
*
* @param credentials
*/
public UserPermissionITCase(Credentials credentials)
{
this.credentials = credentials;
}
//~--- methods --------------------------------------------------------------
/**
* Method description
*
*
* @return
*/
@Parameters
public static Collection<Credentials[]> createParameters()
{
Collection<Credentials[]> params = new ArrayList<Credentials[]>();
params.add(new Credentials[] { new Credentials() });
User dent = createTestUser();
params.add(new Credentials[] {
new Credentials(dent.getName(), dent.getPassword()) });
return params;
}
/**
* Method description
*
*
* @return
*/
private static User createTestUser()
{
User dent = UserTestData.createDent();
dent.setPassword("a.dent124");
Client client = createClient();
authenticateAdmin(client);
WebResource wr = createResource(client, "users");
ClientResponse response = wr.post(ClientResponse.class, dent);
assertNotNull(response);
assertTrue(response.getStatus() == 201);
response.close();
logoutClient(client);
client.destroy();
return dent;
}
/**
* Method description
*
*/
@After
public void after()
{
client = createClient();
logout();
}
/**
* Method description
*
*/
@Before
public void before()
{
client = createClient();
login();
}
/**
* Method description
*
*/
@Test
public void create()
{
WebResource wr = createResource(client, "users");
User zaphod = UserTestData.createZaphod();
checkResponse(wr.post(ClientResponse.class, zaphod));
}
/**
* Method description
*
*/
@Test
public void delete()
{
WebResource wr = createResource(client, "users/scmadmin");
checkResponse(wr.delete(ClientResponse.class));
}
/**
* Method description
*
*/
@Test
public void modify()
{
WebResource wr = createResource(client, "users/scmadmin");
User user = new User("scmadmin", "SCM Administrator",
"scm-admin@scm-manager.org");
user.setPassword("hallo123");
user.setAdmin(true);
user.setType("xml");
checkResponse(wr.put(ClientResponse.class, user));
super(credentials);
}
//~--- get methods ----------------------------------------------------------
@@ -199,158 +65,79 @@ public class UserPermissionITCase
/**
* Method description
*
*
* @return
*/
@Test
public void get()
@Override
protected String getBasePath()
{
WebResource wr = createResource(client, "users/scmadmin");
checkResponse(wr.get(ClientResponse.class));
return "users";
}
/**
* Method description
*
*/
@Test
public void getAll()
{
WebResource wr = createResource(client, "users");
checkResponse(wr.get(ClientResponse.class));
}
//~--- methods --------------------------------------------------------------
/**
* Method description
*
*
* @param response
* @return
*/
private void checkResponse(ClientResponse response)
@Override
protected User getCreateItem()
{
assertNotNull(response);
System.out.append("STATUS: ").println(response.getStatus());
if (credentials.isAnonymous())
{
assertTrue(response.getStatus() == 401);
}
else
{
assertTrue(response.getStatus() == 403);
}
response.close();
return UserTestData.createZaphod();
}
/**
* Method description
*
*
* @return
*/
private void login()
@Override
protected String getDeletePath()
{
if (!credentials.isAnonymous())
{
authenticate(client, credentials.getUsername(),
credentials.getPassword());
}
return "users/scmadmin";
}
/**
* Method description
*
*
* @return
*/
private void logout()
@Override
protected String getGetPath()
{
if (!credentials.isAnonymous())
{
logoutClient(client);
}
return "users/scmadmin";
}
//~--- inner classes --------------------------------------------------------
/**
* Class description
* Method description
*
*
* @version Enter version here..., 2011-02-19
* @author Sebastian Sdorra
* @return
*/
public static class Credentials
@Override
protected User getModifyItem()
{
User user = new User("scmadmin", "SCM Administrator",
"scm-admin@scm-manager.org");
/**
* Constructs ...
*
*/
public Credentials() {}
user.setPassword("hallo123");
user.setAdmin(true);
user.setType("xml");
/**
* Constructs ...
*
*
* @param username
* @param password
*/
public Credentials(String username, String password)
{
this.password = password;
this.username = username;
}
//~--- get methods --------------------------------------------------------
/**
* Method description
*
*
* @return
*/
public String getPassword()
{
return password;
}
/**
* Method description
*
*
* @return
*/
public String getUsername()
{
return username;
}
/**
* Method description
*
*
* @return
*/
public boolean isAnonymous()
{
return Util.isEmpty(username) && Util.isEmpty(password);
}
//~--- fields -------------------------------------------------------------
/** Field description */
private String password;
/** Field description */
private String username;
return user;
}
//~--- fields ---------------------------------------------------------------
/** Field description */
protected Client client;
/** Field description */
private Credentials credentials;
/**
* Method description
*
*
* @return
*/
@Override
protected String getModifyPath()
{
return "users/scmadmin";
}
}