Skip to content

Commit

Permalink
Revert "Fix to update user groups"
Browse files Browse the repository at this point in the history
  • Loading branch information
AssahBismarkabah authored Nov 15, 2024
1 parent b53acdc commit c2b5bd9
Show file tree
Hide file tree
Showing 10 changed files with 22 additions and 36 deletions.
4 changes: 0 additions & 4 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,11 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),

## [Unreleased]

### Fixed
- Fix to update user groups [#1132](https://github.com/adorsys/keycloak-config-cli/issues/1132)

## Fixed
- otpPolicyAlgorithm ignored during import [#847](https://github.com/adorsys/keycloak-config-cli/issues/847)

### Added
- Added Navigation in the readme [#1099](https://github.com/adorsys/keycloak-config-cli/issues/1099)

### Added
- improved logging for realm retrieval errors [#1010](https://github.com/adorsys/keycloak-config-cli/issues/1010)
### Fixed
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -183,11 +183,7 @@ private void handleGroups() {
.toList();

handleGroupsToBeAdded(userGroupsToUpdate, existingUserGroups);

if (importConfigProperties.getManaged().getGroup()
== ImportConfigProperties.ImportManagedProperties.ImportManagedPropertiesValues.FULL) {
handleGroupsToBeRemoved(userGroupsToUpdate, existingUserGroups);
}
handleGroupsToBeRemoved(userGroupsToUpdate, existingUserGroups);
}

private void handleGroupsToBeAdded(
Expand Down
2 changes: 1 addition & 1 deletion src/main/resources/application.properties
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ import.behaviors.sync-user-federation=false
import.behaviors.checksum-with-cache-key=true
import.behaviors.checksum-changed=continue
import.managed.authentication-flow=full
import.managed.group=no-delete
import.managed.group=full
import.managed.required-action=full
import.managed.client-scope=full
import.managed.scope-mapping=full
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1689,7 +1689,7 @@ void shouldUpdateRealmUpdateGroupWithSubstringOfExistingGroupName() throws IOExc

@Test
@Order(78)
void shouldUpdateRealmAddedGroup() throws IOException {
void shouldUpdateRealmDeleteGroup() throws IOException {
GroupRepresentation updatedGroup = tryToLoadGroup("/My Added Group").get();
assertThat(updatedGroup.getName(), Matchers.is(Matchers.equalTo("My Added Group")));

Expand All @@ -1702,7 +1702,7 @@ void shouldUpdateRealmAddedGroup() throws IOException {

assertThat(realm.getRealm(), is(REALM_NAME));

assertThat(tryToLoadGroup("/My Added Group").isPresent(), is(true));
assertThat(tryToLoadGroup("/My Added Group").isPresent(), is(false));
assertThat(tryToLoadGroup("/My Group").isPresent(), is(true));
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -159,7 +159,7 @@ void importFederationChangeUserGroupWithReadonlyProvider() throws IOException {
assertThat(user.getFirstName(), is("James"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(2));
assertThat(userGroups, hasSize(1));

GroupRepresentation group = getGroupsByPath(userGroups, "/realm/group2");
assertThat(group, is(notNullValue()));
Expand All @@ -182,7 +182,7 @@ void importFederationRemoveUserGroupWithReadonlyProvider() throws IOException {
assertThat(user.getFirstName(), is("James"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(2));
assertThat(userGroups, hasSize(0));
}

@Test
Expand All @@ -201,7 +201,7 @@ void importFederationUserChangeAttributeWithReadonlyProvider() throws IOExceptio
assertThat(user.getFirstName(), is("James"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(2));
assertThat(userGroups, hasSize(0));
}

private List<GroupRepresentation> getGroupsByUser(UserRepresentation user) {
Expand Down
22 changes: 11 additions & 11 deletions src/test/java/de/adorsys/keycloak/config/service/ImportUsersIT.java
Original file line number Diff line number Diff line change
Expand Up @@ -400,7 +400,8 @@ void shouldUpdateRealmUpdateUserChangeGroup() throws IOException {

@Test
@Order(11)
void shouldUpdateRealmUpdateUserKeepExistingGroups() throws IOException {
void shouldUpdateRealmUpdateUserRemoveGroup() throws IOException {
// Create Users
doImport("11_update_realm_update_user_remove_group.json");

final RealmRepresentation realm = keycloakProvider.getInstance().realm(REALM_NAME).toRepresentation();
Expand All @@ -413,10 +414,10 @@ void shouldUpdateRealmUpdateUserKeepExistingGroups() throws IOException {
assertThat(user.getFirstName(), is("firstName1"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(2)); // User should still be in both groups
assertThat(userGroups, hasSize(1));

GroupRepresentation group1 = getGroupsByPath(userGroups, "/group1");
assertThat(group1.getName(), is("group1"));
assertThat(group1, nullValue());

GroupRepresentation group2 = getGroupsByPath(userGroups, "/group2");
assertThat(group2.getName(), is("group2"));
Expand All @@ -438,17 +439,16 @@ void shouldUpdateRealmUpdateUserAddSubGroup() throws IOException {
assertThat(user.getFirstName(), is("firstName1"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(3)); // User should now be in all groups
assertThat(userGroups, hasSize(1));

GroupRepresentation group1 = getGroupsByPath(userGroups, "/group1/subgroup1");
assertThat(group1.getName(), is("subgroup1"));
GroupRepresentation group2 = getGroupsByPath(userGroups, "/group2");
assertThat(group2.getName(), is("group2"));
}

@Test
@Order(13)
void shouldUpdateRealmUpdateUserAddNewSubGroup() throws IOException {
void shouldUpdateRealmUpdateUserChangeSubGroup() throws IOException {
// Create Users
doImport("13_update_realm_update_user_change_subgroup.json");

final RealmRepresentation realm = keycloakProvider.getInstance().realm(REALM_NAME).toRepresentation();
Expand All @@ -461,7 +461,7 @@ void shouldUpdateRealmUpdateUserAddNewSubGroup() throws IOException {
assertThat(user.getFirstName(), is("firstName1"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(4)); // User should now be in all groups
assertThat(userGroups, hasSize(2));

GroupRepresentation group1 = getGroupsByPath(userGroups, "/group1/subgroup1");
assertThat(group1.getName(), is("subgroup1"));
Expand All @@ -472,7 +472,7 @@ void shouldUpdateRealmUpdateUserAddNewSubGroup() throws IOException {

@Test
@Order(14)
void shouldUpdateRealmUpdateUserKeepExistingSubGroups() throws IOException {
void shouldUpdateRealmUpdateUserRemoveSubGroup() throws IOException {
doImport("14_update_realm_update_user_remove_subgroup.json");

final RealmRepresentation realm = keycloakProvider.getInstance().realm(REALM_NAME).toRepresentation();
Expand All @@ -485,10 +485,10 @@ void shouldUpdateRealmUpdateUserKeepExistingSubGroups() throws IOException {
assertThat(user.getFirstName(), is("firstName1"));

List<GroupRepresentation> userGroups = getGroupsByUser(user);
assertThat(userGroups, hasSize(4));
assertThat(userGroups, hasSize(1));

GroupRepresentation group1 = getGroupsByPath(userGroups, "/group1/subgroup1");
assertThat(group1.getName(), is("subgroup1"));
assertThat(group1, nullValue());

GroupRepresentation group2 = getGroupsByPath(userGroups, "/group2/subgroup2");
assertThat(group2.getName(), is("subgroup2"));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,7 @@
"firstName": "firstName1",
"lastName": "lastName1",
"groups": [
"group2",
"group1"
"group2"
]
},
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,7 @@
"firstName": "firstName1",
"lastName": "lastName1",
"groups": [
"/group1/subgroup1",
"/group1",
"/group2"
"/group1/subgroup1"
]
},
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,7 @@
"lastName": "lastName1",
"groups": [
"/group1/subgroup1",
"/group2/subgroup2",
"/group1",
"/group2"
"/group2/subgroup2"
]
},
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,7 @@
"firstName": "firstName1",
"lastName": "lastName1",
"groups": [
"/group2/subgroup2",
"/group1/subgroup1"
"/group2/subgroup2"
]
},
{
Expand Down

0 comments on commit c2b5bd9

Please sign in to comment.