Resolving Issue #860 - Warned Attack Styles not properly hiding. Adding automated test coverage for AttackIndicatorPlugin.
This commit is contained in:
@@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
package net.runelite.client.plugins.attackindicator;
|
package net.runelite.client.plugins.attackindicator;
|
||||||
|
|
||||||
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import com.google.common.collect.HashBasedTable;
|
import com.google.common.collect.HashBasedTable;
|
||||||
import com.google.common.collect.Table;
|
import com.google.common.collect.Table;
|
||||||
import com.google.common.eventbus.Subscribe;
|
import com.google.common.eventbus.Subscribe;
|
||||||
@@ -230,9 +231,9 @@ public class AttackIndicatorPlugin extends Plugin
|
|||||||
break;
|
break;
|
||||||
case "removeWarnedStyles":
|
case "removeWarnedStyles":
|
||||||
hideWarnedStyles(enabled);
|
hideWarnedStyles(enabled);
|
||||||
processWidgets();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
processWidgets();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -355,4 +356,16 @@ public class AttackIndicatorPlugin extends Plugin
|
|||||||
widget.setHidden(hidden);
|
widget.setHidden(hidden);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
Set<Skill> getWarnedSkills()
|
||||||
|
{
|
||||||
|
return warnedSkills;
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
Table<WeaponType, WidgetInfo, Boolean> getHiddenWidgets()
|
||||||
|
{
|
||||||
|
return widgetsToHide;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,185 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package net.runelite.client.plugins.attackindicator;
|
||||||
|
|
||||||
|
import com.google.inject.Guice;
|
||||||
|
import com.google.inject.testing.fieldbinder.Bind;
|
||||||
|
import com.google.inject.testing.fieldbinder.BoundFieldModule;
|
||||||
|
import java.util.Set;
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.Setting;
|
||||||
|
import net.runelite.api.Skill;
|
||||||
|
import net.runelite.api.Varbits;
|
||||||
|
import net.runelite.api.events.ConfigChanged;
|
||||||
|
import net.runelite.api.events.VarbitChanged;
|
||||||
|
import net.runelite.api.widgets.Widget;
|
||||||
|
import net.runelite.api.widgets.WidgetInfo;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
import org.mockito.runners.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class AttackIndicatorPluginTest
|
||||||
|
{
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
Client client;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
AttackIndicatorConfig attackConfig;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
AttackIndicatorPlugin attackPlugin;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before()
|
||||||
|
{
|
||||||
|
Guice.createInjector(BoundFieldModule.of(this)).injectMembers(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that red text is displayed when attacking with a style that gains experience
|
||||||
|
* in one of the unwanted skills.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testWarning()
|
||||||
|
{
|
||||||
|
ConfigChanged warnForAttackEvent = new ConfigChanged();
|
||||||
|
warnForAttackEvent.setGroup("attackIndicator");
|
||||||
|
warnForAttackEvent.setKey("warnForAttack");
|
||||||
|
warnForAttackEvent.setNewValue("true");
|
||||||
|
attackPlugin.onConfigChanged(warnForAttackEvent);
|
||||||
|
|
||||||
|
// Verify there is a warned skill
|
||||||
|
Set<Skill> warnedSkills = attackPlugin.getWarnedSkills();
|
||||||
|
assertTrue(warnedSkills.contains(Skill.ATTACK));
|
||||||
|
|
||||||
|
// Set mock client to attack in style that gives attack xp
|
||||||
|
when(client.getSetting(Setting.ATTACK_STYLE)).thenReturn(AttackStyle.ACCURATE.ordinal());
|
||||||
|
|
||||||
|
// verify that earning xp in a warned skill will display red text on the widget
|
||||||
|
attackPlugin.onAttackStyleChange(new VarbitChanged());
|
||||||
|
assertTrue(attackPlugin.isWarnedSkillSelected());
|
||||||
|
|
||||||
|
// Switch to attack style that doesn't give attack xp
|
||||||
|
when(client.getSetting(Setting.ATTACK_STYLE)).thenReturn(AttackStyle.AGGRESSIVE.ordinal());
|
||||||
|
|
||||||
|
// Verify the widget will now display white text
|
||||||
|
attackPlugin.onAttackStyleChange(new VarbitChanged());
|
||||||
|
warnedSkills = attackPlugin.getWarnedSkills();
|
||||||
|
assertTrue(warnedSkills.contains(Skill.ATTACK));
|
||||||
|
assertFalse(attackPlugin.isWarnedSkillSelected());
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Verify that attack style widgets are hidden when filtered with the AttackIndicatorPlugin.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testHiddenWidget()
|
||||||
|
{
|
||||||
|
ConfigChanged warnForAttackEvent = new ConfigChanged();
|
||||||
|
warnForAttackEvent.setGroup("attackIndicator");
|
||||||
|
warnForAttackEvent.setKey("warnForAttack");
|
||||||
|
warnForAttackEvent.setNewValue("true");
|
||||||
|
attackPlugin.onConfigChanged(warnForAttackEvent);
|
||||||
|
|
||||||
|
// Set up mock widgets for atk and str attack styles
|
||||||
|
Widget atkWidget = mock(Widget.class);
|
||||||
|
Widget strWidget = mock(Widget.class);
|
||||||
|
when(client.getWidget(WidgetInfo.COMBAT_STYLE_ONE)).thenReturn(atkWidget);
|
||||||
|
when(client.getWidget(WidgetInfo.COMBAT_STYLE_TWO)).thenReturn(strWidget);
|
||||||
|
// Set widgets to return their hidden value in widgetsToHide when isHidden() is called
|
||||||
|
when(atkWidget.isHidden()).thenAnswer(x -> isAtkHidden());
|
||||||
|
when(strWidget.isHidden()).thenAnswer(x -> isStrHidden());
|
||||||
|
|
||||||
|
// equip type_4 weapon type on player
|
||||||
|
when(client.getSetting(Varbits.EQUIPPED_WEAPON_TYPE)).thenReturn(WeaponType.TYPE_4.ordinal());
|
||||||
|
attackPlugin.onEquippedWeaponTypeChange(new VarbitChanged());
|
||||||
|
|
||||||
|
// Verify there is a warned skill
|
||||||
|
Set<Skill> warnedSkills = attackPlugin.getWarnedSkills();
|
||||||
|
assertTrue(warnedSkills.contains(Skill.ATTACK));
|
||||||
|
|
||||||
|
// Enable hiding widgets
|
||||||
|
ConfigChanged hideWidgetEvent = new ConfigChanged();
|
||||||
|
hideWidgetEvent.setGroup("attackIndicator");
|
||||||
|
hideWidgetEvent.setKey("removeWarnedStyles");
|
||||||
|
hideWidgetEvent.setNewValue("true");
|
||||||
|
attackPlugin.onConfigChanged(hideWidgetEvent);
|
||||||
|
when(attackConfig.removeWarnedStyles()).thenReturn(true);
|
||||||
|
|
||||||
|
// verify that the accurate attack style widget is hidden
|
||||||
|
assertTrue(atkWidget.isHidden());
|
||||||
|
|
||||||
|
// add another warned skill
|
||||||
|
ConfigChanged warnForStrengthEvent = new ConfigChanged();
|
||||||
|
warnForStrengthEvent.setGroup("attackIndicator");
|
||||||
|
warnForStrengthEvent.setKey("warnForStrength");
|
||||||
|
warnForStrengthEvent.setNewValue("true");
|
||||||
|
attackPlugin.onConfigChanged(warnForStrengthEvent);
|
||||||
|
|
||||||
|
// verify that the aggressive attack style widget is now hidden
|
||||||
|
assertTrue(strWidget.isHidden());
|
||||||
|
|
||||||
|
// disable hiding attack style widgets
|
||||||
|
hideWidgetEvent.setGroup("attackIndicator");
|
||||||
|
hideWidgetEvent.setKey("removeWarnedStyles");
|
||||||
|
hideWidgetEvent.setNewValue("false");
|
||||||
|
attackPlugin.onConfigChanged(hideWidgetEvent);
|
||||||
|
when(attackConfig.removeWarnedStyles()).thenReturn(false);
|
||||||
|
|
||||||
|
// verify that the aggressive and accurate attack style widgets are no longer hidden
|
||||||
|
assertFalse(attackPlugin.getHiddenWidgets().get(WeaponType.TYPE_4,
|
||||||
|
WidgetInfo.COMBAT_STYLE_ONE));
|
||||||
|
assertFalse(attackPlugin.getHiddenWidgets().get(WeaponType.TYPE_4,
|
||||||
|
WidgetInfo.COMBAT_STYLE_THREE));
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isAtkHidden()
|
||||||
|
{
|
||||||
|
if (attackPlugin.getHiddenWidgets().size() == 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return attackPlugin.getHiddenWidgets().get(WeaponType.TYPE_4, WidgetInfo.COMBAT_STYLE_ONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isStrHidden()
|
||||||
|
{
|
||||||
|
if (attackPlugin.getHiddenWidgets().size() == 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return attackPlugin.getHiddenWidgets().get(WeaponType.TYPE_4, WidgetInfo.COMBAT_STYLE_TWO);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user