基本的なユーザー/ロールを実装しようとしています
ユーザーは、0から多数の役割を持つことができます。
public enum Role {
ROLE_USER,
ROLE_ADMIN;
}
@Entity
@Table(name = "USERS")
public class User implements Serializable {
private static final long serialVersionUID = 2936736450886451500L;
private Long id;
private Individual individual;
private Set<Role> roles = new HashSet<Role>();
@Id
@Column(name = "ID")
@GeneratedValue
public Long getId() {
return id;
}
@SuppressWarnings("unused")
private void setId(Long id) {
this.id = id;
}
@ElementCollection(targetClass=Role.class)
@JoinTable(name = "USER_ROLES", joinColumns = @JoinColumn(name = "USER_ID"))
@Enumerated(EnumType.STRING)
@Column(name = "role", nullable = false)
public Set<Role> getRoles() {
return roles;
}
public void setRoles(Set<Role> roles) {
this.roles = roles;
}
public void addRole(Role role) {
roles.add(role);
}
}
私のユニットテスト
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({"classpath:/META-INF/spring/resources/resource-context.xml", "classpath:/META-INF/spring/services/persistence-context.xml"})
public class UserDaoJpaImplTest {
@Autowired
UserDao userDao;
@Transactional
@Test
public void testCreate() {
User user = new User();
user.setIndividual(new Individual());
user.addRole(Role.ROLE_USER);
user.addRole(Role.ROLE_ADMIN);
userDao.create(user);
Assert.assertNotSame(user.getId(), 0);
}
問題は、jpa(hibernateによってサポートされている)がUSER_ROLESテーブルに挿入を行っていないことです(ユーザーに対して正しい複合PK(ROLE、USER_ID)とFKを使用して正しく作成しています。
コンソールで、ユーザーに対して1回の挿入のみが行われていることがわかります。
Hibernate: insert into USERS (INDIVIDUAL_ID) values ( ? )
Hibernate: insert into INDIVIDUALS values ( )
単純なものが欠けているだけだと思います。