From 1706bf6abcf2ce253e086066beb1574fce0de139 Mon Sep 17 00:00:00 2001 From: Edwin Kempin Date: Tue, 19 Feb 2013 12:39:27 +0100 Subject: [PATCH] Add acceptance test to retrieve group via REST Change-Id: Ib48016b695bd7707821fc4e1da2e5a1a97923f06 Signed-off-by: Edwin Kempin --- .../acceptance/rest/group/GetGroupIT.java | 73 +++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/group/GetGroupIT.java diff --git a/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/group/GetGroupIT.java b/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/group/GetGroupIT.java new file mode 100644 index 0000000000..e76687e609 --- /dev/null +++ b/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/group/GetGroupIT.java @@ -0,0 +1,73 @@ +// Copyright (C) 2013 The Android Open Source Project +// +// Licensed 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 com.google.gerrit.acceptance.rest.group; + +import static com.google.gerrit.acceptance.rest.group.GroupAssert.assertGroupInfo; + +import com.google.common.reflect.TypeToken; +import com.google.gerrit.acceptance.AbstractDaemonTest; +import com.google.gerrit.acceptance.AccountCreator; +import com.google.gerrit.acceptance.RestResponse; +import com.google.gerrit.acceptance.RestSession; +import com.google.gerrit.acceptance.TestAccount; +import com.google.gerrit.reviewdb.client.AccountGroup; +import com.google.gerrit.server.account.GroupCache; +import com.google.gson.Gson; +import com.google.inject.Inject; + +import org.junit.Before; +import org.junit.Test; + +import java.io.IOException; + +public class GetGroupIT extends AbstractDaemonTest { + + @Inject + private AccountCreator accounts; + + @Inject + private GroupCache groupCache; + + private TestAccount admin; + private RestSession session; + + @Before + public void setUp() throws Exception { + admin = accounts.create("admin", "admin@example.com", "Administrator", + "Administrators"); + session = new RestSession(admin); + } + + @Test + public void testGetGroup() throws IOException { + AccountGroup adminGroup = groupCache.get(new AccountGroup.NameKey("Administrators")); + + // by UUID + testGetGroup("/groups/" + adminGroup.getGroupUUID().get(), adminGroup); + + // by name + testGetGroup("/groups/" + adminGroup.getName(), adminGroup); + + // by legacy numeric ID + testGetGroup("/groups/" + adminGroup.getId().get(), adminGroup); + } + + private void testGetGroup(String url, AccountGroup expectedGroup) throws IOException { + RestResponse r = session.get(url); + @SuppressWarnings("serial") + GroupInfo group = (new Gson()).fromJson(r.getReader(), new TypeToken() {}.getType()); + assertGroupInfo(expectedGroup, group); + } +}