summaryrefslogtreecommitdiffstats
path: root/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java
diff options
context:
space:
mode:
Diffstat (limited to 'gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java')
-rw-r--r--gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java313
1 files changed, 0 insertions, 313 deletions
diff --git a/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java b/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java
deleted file mode 100644
index 08f0699e59..0000000000
--- a/gerrit-acceptance-tests/src/test/java/com/google/gerrit/acceptance/rest/change/HashtagsIT.java
+++ /dev/null
@@ -1,313 +0,0 @@
-// Copyright (C) 2014 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.change;
-
-import static com.google.common.base.Preconditions.checkNotNull;
-import static com.google.common.truth.Truth.assertThat;
-import static com.google.common.truth.TruthJUnit.assume;
-import static com.google.gerrit.server.group.SystemGroupBackend.REGISTERED_USERS;
-import static java.util.concurrent.TimeUnit.SECONDS;
-
-import com.google.common.collect.Iterables;
-import com.google.common.collect.Sets;
-import com.google.common.truth.IterableSubject;
-import com.google.gerrit.acceptance.AbstractDaemonTest;
-import com.google.gerrit.acceptance.NoHttpd;
-import com.google.gerrit.acceptance.PushOneCommit;
-import com.google.gerrit.common.data.Permission;
-import com.google.gerrit.extensions.api.changes.HashtagsInput;
-import com.google.gerrit.extensions.common.ChangeMessageInfo;
-import com.google.gerrit.extensions.restapi.AuthException;
-import com.google.gerrit.extensions.restapi.BadRequestException;
-import com.google.gerrit.testutil.TestTimeUtil;
-import org.junit.AfterClass;
-import org.junit.Before;
-import org.junit.BeforeClass;
-import org.junit.Test;
-
-@NoHttpd
-public class HashtagsIT extends AbstractDaemonTest {
- @Before
- public void before() {
- assume().that(notesMigration.readChanges()).isTrue();
- }
-
- @BeforeClass
- public static void setTimeForTesting() {
- TestTimeUtil.resetWithClockStep(1, SECONDS);
- }
-
- @AfterClass
- public static void restoreTime() {
- TestTimeUtil.useSystemTime();
- }
-
- @Test
- public void getNoHashtags() throws Exception {
- // Get on a change with no hashtags returns an empty list.
- PushOneCommit.Result r = createChange();
- assertThatGet(r).isEmpty();
- }
-
- @Test
- public void addSingleHashtag() throws Exception {
- PushOneCommit.Result r = createChange();
-
- // Adding a single hashtag returns a single hashtag.
- addHashtags(r, "tag2");
- assertThatGet(r).containsExactly("tag2");
- assertMessage(r, "Hashtag added: tag2");
-
- // Adding another single hashtag to change that already has one hashtag
- // returns a sorted list of hashtags with existing and new.
- addHashtags(r, "tag1");
- assertThatGet(r).containsExactly("tag1", "tag2").inOrder();
- assertMessage(r, "Hashtag added: tag1");
- }
-
- @Test
- public void addInvalidHashtag() throws Exception {
- PushOneCommit.Result r = createChange();
-
- exception.expect(BadRequestException.class);
- exception.expectMessage("hashtags may not contain commas");
- addHashtags(r, "invalid,hashtag");
- }
-
- @Test
- public void addMultipleHashtags() throws Exception {
- PushOneCommit.Result r = createChange();
-
- // Adding multiple hashtags returns a sorted list of hashtags.
- addHashtags(r, "tag3", "tag1");
- assertThatGet(r).containsExactly("tag1", "tag3").inOrder();
- assertMessage(r, "Hashtags added: tag1, tag3");
-
- // Adding multiple hashtags to change that already has hashtags returns a
- // sorted list of hashtags with existing and new.
- addHashtags(r, "tag2", "tag4");
- assertThatGet(r).containsExactly("tag1", "tag2", "tag3", "tag4").inOrder();
- assertMessage(r, "Hashtags added: tag2, tag4");
- }
-
- @Test
- public void addAlreadyExistingHashtag() throws Exception {
- // Adding a hashtag that already exists on the change returns a sorted list
- // of hashtags without duplicates.
- PushOneCommit.Result r = createChange();
- addHashtags(r, "tag2");
- assertThatGet(r).containsExactly("tag2");
- assertMessage(r, "Hashtag added: tag2");
- ChangeMessageInfo last = getLastMessage(r);
-
- addHashtags(r, "tag2");
- assertThatGet(r).containsExactly("tag2");
- assertNoNewMessageSince(r, last);
-
- addHashtags(r, "tag1", "tag2");
- assertThatGet(r).containsExactly("tag1", "tag2").inOrder();
- assertMessage(r, "Hashtag added: tag1");
- }
-
- @Test
- public void hashtagsWithPrefix() throws Exception {
- PushOneCommit.Result r = createChange();
-
- // Leading # is stripped from added tag.
- addHashtags(r, "#tag1");
- assertThatGet(r).containsExactly("tag1");
- assertMessage(r, "Hashtag added: tag1");
-
- // Leading # is stripped from multiple added tags.
- addHashtags(r, "#tag2", "#tag3");
- assertThatGet(r).containsExactly("tag1", "tag2", "tag3").inOrder();
- assertMessage(r, "Hashtags added: tag2, tag3");
-
- // Leading # is stripped from removed tag.
- removeHashtags(r, "#tag2");
- assertThatGet(r).containsExactly("tag1", "tag3").inOrder();
- assertMessage(r, "Hashtag removed: tag2");
-
- // Leading # is stripped from multiple removed tags.
- removeHashtags(r, "#tag1", "#tag3");
- assertThatGet(r).isEmpty();
- assertMessage(r, "Hashtags removed: tag1, tag3");
-
- // Leading # and space are stripped from added tag.
- addHashtags(r, "# tag1");
- assertThatGet(r).containsExactly("tag1");
- assertMessage(r, "Hashtag added: tag1");
-
- // Multiple leading # are stripped from added tag.
- addHashtags(r, "##tag2");
- assertThatGet(r).containsExactly("tag1", "tag2").inOrder();
- assertMessage(r, "Hashtag added: tag2");
-
- // Multiple leading spaces and # are stripped from added tag.
- addHashtags(r, "# # tag3");
- assertThatGet(r).containsExactly("tag1", "tag2", "tag3").inOrder();
- assertMessage(r, "Hashtag added: tag3");
- }
-
- @Test
- public void removeSingleHashtag() throws Exception {
- // Removing a single tag from a change that only has that tag returns an
- // empty list.
- PushOneCommit.Result r = createChange();
- addHashtags(r, "tag1");
- assertThatGet(r).containsExactly("tag1");
- removeHashtags(r, "tag1");
- assertThatGet(r).isEmpty();
- assertMessage(r, "Hashtag removed: tag1");
-
- // Removing a single tag from a change that has multiple tags returns a
- // sorted list of remaining tags.
- addHashtags(r, "tag1", "tag2", "tag3");
- removeHashtags(r, "tag2");
- assertThatGet(r).containsExactly("tag1", "tag3").inOrder();
- assertMessage(r, "Hashtag removed: tag2");
- }
-
- @Test
- public void removeMultipleHashtags() throws Exception {
- // Removing multiple tags from a change that only has those tags returns an
- // empty list.
- PushOneCommit.Result r = createChange();
- addHashtags(r, "tag1", "tag2");
- assertThatGet(r).containsExactly("tag1", "tag2").inOrder();
- removeHashtags(r, "tag1", "tag2");
- assertThatGet(r).isEmpty();
- assertMessage(r, "Hashtags removed: tag1, tag2");
-
- // Removing multiple tags from a change that has multiple tags returns a
- // sorted list of remaining tags.
- addHashtags(r, "tag1", "tag2", "tag3", "tag4");
- assertThatGet(r).containsExactly("tag1", "tag2", "tag3", "tag4").inOrder();
- removeHashtags(r, "tag2", "tag4");
- assertThatGet(r).containsExactly("tag1", "tag3").inOrder();
- assertMessage(r, "Hashtags removed: tag2, tag4");
- }
-
- @Test
- public void removeNotExistingHashtag() throws Exception {
- // Removing a single hashtag from change that has no hashtags returns an
- // empty list.
- PushOneCommit.Result r = createChange();
- ChangeMessageInfo last = getLastMessage(r);
- removeHashtags(r, "tag1");
- assertThatGet(r).isEmpty();
- assertNoNewMessageSince(r, last);
-
- // Removing a single non-existing tag from a change that only has one other
- // tag returns a list of only one tag.
- addHashtags(r, "tag1");
- last = getLastMessage(r);
- removeHashtags(r, "tag4");
- assertThatGet(r).containsExactly("tag1");
- assertNoNewMessageSince(r, last);
-
- // Removing a single non-existing tag from a change that has multiple tags
- // returns a sorted list of tags without any deleted.
- addHashtags(r, "tag1", "tag2", "tag3");
- last = getLastMessage(r);
- removeHashtags(r, "tag4");
- assertThatGet(r).containsExactly("tag1", "tag2", "tag3").inOrder();
- assertNoNewMessageSince(r, last);
- }
-
- @Test
- public void addAndRemove() throws Exception {
- // Adding and remove hashtags in a single request performs correctly.
- PushOneCommit.Result r = createChange();
- addHashtags(r, "tag1", "tag2");
- HashtagsInput input = new HashtagsInput();
- input.add = Sets.newHashSet("tag3", "tag4");
- input.remove = Sets.newHashSet("tag1");
- gApi.changes().id(r.getChange().getId().get()).setHashtags(input);
- assertThatGet(r).containsExactly("tag2", "tag3", "tag4");
- assertMessage(r, "Hashtags added: tag3, tag4\nHashtag removed: tag1");
-
- // Adding and removing the same hashtag actually removes it.
- addHashtags(r, "tag1", "tag2");
- input = new HashtagsInput();
- input.add = Sets.newHashSet("tag3", "tag4");
- input.remove = Sets.newHashSet("tag3");
- gApi.changes().id(r.getChange().getId().get()).setHashtags(input);
- assertThatGet(r).containsExactly("tag1", "tag2", "tag4");
- assertMessage(r, "Hashtag removed: tag3");
- }
-
- @Test
- public void hashtagWithMixedCase() throws Exception {
- PushOneCommit.Result r = createChange();
- addHashtags(r, "MyHashtag");
- assertThatGet(r).containsExactly("MyHashtag");
- assertMessage(r, "Hashtag added: MyHashtag");
- }
-
- @Test
- public void addHashtagWithoutPermissionNotAllowed() throws Exception {
- PushOneCommit.Result r = createChange();
- setApiUser(user);
- exception.expect(AuthException.class);
- exception.expectMessage("edit hashtags not permitted");
- addHashtags(r, "MyHashtag");
- }
-
- @Test
- public void addHashtagWithPermissionAllowed() throws Exception {
- PushOneCommit.Result r = createChange();
- grant(project, "refs/heads/master", Permission.EDIT_HASHTAGS, false, REGISTERED_USERS);
- setApiUser(user);
- addHashtags(r, "MyHashtag");
- assertThatGet(r).containsExactly("MyHashtag");
- assertMessage(r, "Hashtag added: MyHashtag");
- }
-
- private IterableSubject assertThatGet(PushOneCommit.Result r) throws Exception {
- return assertThat(gApi.changes().id(r.getChange().getId().get()).getHashtags());
- }
-
- private void addHashtags(PushOneCommit.Result r, String... toAdd) throws Exception {
- HashtagsInput input = new HashtagsInput();
- input.add = Sets.newHashSet(toAdd);
- gApi.changes().id(r.getChange().getId().get()).setHashtags(input);
- }
-
- private void removeHashtags(PushOneCommit.Result r, String... toRemove) throws Exception {
- HashtagsInput input = new HashtagsInput();
- input.remove = Sets.newHashSet(toRemove);
- gApi.changes().id(r.getChange().getId().get()).setHashtags(input);
- }
-
- private void assertMessage(PushOneCommit.Result r, String expectedMessage) throws Exception {
- assertThat(getLastMessage(r).message).isEqualTo(expectedMessage);
- }
-
- private void assertNoNewMessageSince(PushOneCommit.Result r, ChangeMessageInfo expected)
- throws Exception {
- checkNotNull(expected);
- ChangeMessageInfo last = getLastMessage(r);
- assertThat(last.message).isEqualTo(expected.message);
- assertThat(last.id).isEqualTo(expected.id);
- }
-
- private ChangeMessageInfo getLastMessage(PushOneCommit.Result r) throws Exception {
- ChangeMessageInfo lastMessage =
- Iterables.getLast(gApi.changes().id(r.getChange().getId().get()).get().messages, null);
- assertThat(lastMessage).named(lastMessage.message).isNotNull();
- return lastMessage;
- }
-}