blob: 2e0a1fcc9e5d5b275c70f517da55ee3050d57dbb [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.deltaspike.data.impl.audit;
import static org.apache.deltaspike.data.test.util.TestDeployments.initDeployment;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import javax.enterprise.inject.Produces;
import org.apache.deltaspike.data.api.audit.CurrentUser;
import org.apache.deltaspike.data.test.TransactionalTestCase;
import org.apache.deltaspike.data.test.domain.AuditedEntity;
import org.apache.deltaspike.data.test.domain.Principal;
import org.apache.deltaspike.test.category.WebProfileCategory;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.shrinkwrap.api.Archive;
import org.junit.Test;
import org.junit.experimental.categories.Category;
@Category(WebProfileCategory.class)
public class AuditEntityListenerTest extends TransactionalTestCase
{
@Deployment
public static Archive<?> deployment()
{
return initDeployment()
.addPackage(AuditEntityListener.class.getPackage())
.addAsWebInfResource("test-orm.xml", "classes/META-INF/orm.xml")
.addPackage(AuditedEntity.class.getPackage());
}
private final String who = "test999";
private final Principal principal = new Principal(who);
@Produces
@CurrentUser
public String who()
{
return who;
}
@Produces
@CurrentUser
public Principal entity() throws Exception
{
try
{
getEntityManager().persist(principal);
}
catch (Throwable e)
{
}
return principal;
}
@Test
public void should_set_creation_date() throws Exception
{
// given
AuditedEntity entity = new AuditedEntity();
// when
getEntityManager().persist(entity);
getEntityManager().flush();
// then
assertNotNull(entity.getCreated());
assertNotNull(entity.getModified());
assertEquals(entity.getCreated().getTime(), entity.getModified());
}
@Test
public void should_set_modification_date() throws Exception
{
// given
AuditedEntity entity = new AuditedEntity();
getEntityManager().persist(entity);
getEntityManager().flush();
// when
entity = getEntityManager().find(AuditedEntity.class, entity.getId());
entity.setName("test");
getEntityManager().flush();
// then
assertNotNull(entity.getGregorianModified());
assertNotNull(entity.getTimestamp());
}
@Test
public void should_set_changing_principal()
{
// given
AuditedEntity entity = new AuditedEntity();
getEntityManager().persist(entity);
getEntityManager().flush();
// when
entity = getEntityManager().find(AuditedEntity.class, entity.getId());
entity.setName("test");
getEntityManager().flush();
// then
assertNotNull(entity.getChanger());
assertEquals(who, entity.getChanger());
assertNotNull(entity.getPrincipal());
assertEquals(who, entity.getPrincipal().getName());
assertNotNull(entity.getChangerOnly());
assertEquals(who, entity.getChangerOnly());
assertNotNull(entity.getChangerOnlyPrincipal());
assertEquals(who, entity.getChangerOnlyPrincipal().getName());
}
@Test
public void should_set_creating_principal()
{
// given
AuditedEntity entity = new AuditedEntity();
// when
getEntityManager().persist(entity);
getEntityManager().flush();
// then
assertNotNull(entity.getCreator());
assertEquals(who, entity.getCreator());
assertNotNull(entity.getCreatorPrincipal());
assertEquals(who, entity.getCreatorPrincipal().getName());
assertNotNull(entity.getChanger());
assertEquals(who, entity.getChanger());
assertNotNull(entity.getPrincipal());
assertEquals(who, entity.getPrincipal().getName());
assertNull(entity.getChangerOnly());
assertNull(entity.getChangerOnlyPrincipal());
}
}