prayer plugin: fix time remaining text when greater than 1 hour
This commit is contained in:
@@ -361,9 +361,14 @@ public class PrayerPlugin extends Plugin
|
|||||||
|
|
||||||
LocalTime timeLeft = LocalTime.ofSecondOfDay((long) secondsLeft);
|
LocalTime timeLeft = LocalTime.ofSecondOfDay((long) secondsLeft);
|
||||||
|
|
||||||
if (formatForOrb && timeLeft.getMinute() > 9)
|
if (formatForOrb && (timeLeft.getHour() > 0 || timeLeft.getMinute() > 9))
|
||||||
{
|
{
|
||||||
return timeLeft.format(DateTimeFormatter.ofPattern("m")) + "m";
|
long minutes = Duration.ofSeconds((long) secondsLeft).toMinutes();
|
||||||
|
return String.format("%dm", minutes);
|
||||||
|
}
|
||||||
|
else if (timeLeft.getHour() > 0)
|
||||||
|
{
|
||||||
|
return timeLeft.format(DateTimeFormatter.ofPattern("H:mm:ss"));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -0,0 +1,154 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2020, Landy Chan <https://github.com/landychan>
|
||||||
|
* 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.prayer;
|
||||||
|
|
||||||
|
import com.google.inject.Guice;
|
||||||
|
import com.google.inject.testing.fieldbinder.Bind;
|
||||||
|
import com.google.inject.testing.fieldbinder.BoundFieldModule;
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.EquipmentInventorySlot;
|
||||||
|
import net.runelite.api.InventoryID;
|
||||||
|
import net.runelite.api.Item;
|
||||||
|
import net.runelite.api.ItemContainer;
|
||||||
|
import net.runelite.api.Prayer;
|
||||||
|
import net.runelite.api.Skill;
|
||||||
|
import net.runelite.api.events.ItemContainerChanged;
|
||||||
|
import net.runelite.client.game.ItemManager;
|
||||||
|
import net.runelite.client.ui.overlay.OverlayManager;
|
||||||
|
import net.runelite.client.ui.overlay.infobox.InfoBoxManager;
|
||||||
|
import net.runelite.http.api.item.ItemEquipmentStats;
|
||||||
|
import net.runelite.http.api.item.ItemStats;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||||
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class PrayerPluginTest
|
||||||
|
{
|
||||||
|
private static final ItemStats HIGH_PRAYER_BONUS_WEAPON = new ItemStats(false, false, 0, 0,
|
||||||
|
ItemEquipmentStats.builder()
|
||||||
|
.slot(EquipmentInventorySlot.WEAPON.getSlotIdx())
|
||||||
|
.prayer(50)
|
||||||
|
.build());
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
private PrayerPlugin prayerPlugin;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
private Client client;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
private PrayerConfig config;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
private OverlayManager overlayManager;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
private InfoBoxManager infoBoxManager;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
private ItemManager itemManager;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before()
|
||||||
|
{
|
||||||
|
Guice.createInjector(BoundFieldModule.of(this)).injectMembers(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetEstimatedTimeRemainingOverOneHour()
|
||||||
|
{
|
||||||
|
ItemContainer itemContainer = mock(ItemContainer.class);
|
||||||
|
when(itemContainer.getItems()).thenReturn(new Item[]{new Item(-1, 1)});
|
||||||
|
when(itemManager.getItemStats(anyInt(), anyBoolean())).thenReturn(HIGH_PRAYER_BONUS_WEAPON);
|
||||||
|
|
||||||
|
when(client.isPrayerActive(Prayer.PRESERVE)).thenReturn(true);
|
||||||
|
when(client.getBoostedSkillLevel(Skill.PRAYER)).thenReturn(99);
|
||||||
|
when(client.getItemContainer(InventoryID.EQUIPMENT)).thenReturn(itemContainer);
|
||||||
|
|
||||||
|
prayerPlugin.onItemContainerChanged(new ItemContainerChanged(InventoryID.EQUIPMENT.getId(), itemContainer));
|
||||||
|
|
||||||
|
assertEquals("1:19:12", prayerPlugin.getEstimatedTimeRemaining(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetEstimatedTimeRemainingUnderOneHour()
|
||||||
|
{
|
||||||
|
ItemContainer itemContainer = mock(ItemContainer.class);
|
||||||
|
when(itemContainer.getItems()).thenReturn(new Item[]{});
|
||||||
|
|
||||||
|
when(client.isPrayerActive(Prayer.PRESERVE)).thenReturn(true);
|
||||||
|
when(client.getBoostedSkillLevel(Skill.PRAYER)).thenReturn(99);
|
||||||
|
when(client.getItemContainer(InventoryID.EQUIPMENT)).thenReturn(itemContainer);
|
||||||
|
|
||||||
|
prayerPlugin.onItemContainerChanged(new ItemContainerChanged(InventoryID.EQUIPMENT.getId(), itemContainer));
|
||||||
|
|
||||||
|
assertEquals("29:42", prayerPlugin.getEstimatedTimeRemaining(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetEstimatedTimeRemainingFormatForOrbUnderOneHour()
|
||||||
|
{
|
||||||
|
ItemContainer itemContainer = mock(ItemContainer.class);
|
||||||
|
when(itemContainer.getItems()).thenReturn(new Item[]{});
|
||||||
|
|
||||||
|
when(client.isPrayerActive(Prayer.PRESERVE)).thenReturn(true);
|
||||||
|
when(client.getBoostedSkillLevel(Skill.PRAYER)).thenReturn(99);
|
||||||
|
when(client.getItemContainer(InventoryID.EQUIPMENT)).thenReturn(itemContainer);
|
||||||
|
|
||||||
|
prayerPlugin.onItemContainerChanged(new ItemContainerChanged(InventoryID.EQUIPMENT.getId(), itemContainer));
|
||||||
|
|
||||||
|
assertEquals("29m", prayerPlugin.getEstimatedTimeRemaining(true));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetEstimatedTimeRemainingFormatForOrbOverOneHour()
|
||||||
|
{
|
||||||
|
ItemContainer itemContainer = mock(ItemContainer.class);
|
||||||
|
when(itemContainer.getItems()).thenReturn(new Item[]{new Item(-1, 1)});
|
||||||
|
when(itemManager.getItemStats(anyInt(), anyBoolean())).thenReturn(HIGH_PRAYER_BONUS_WEAPON);
|
||||||
|
|
||||||
|
when(client.isPrayerActive(Prayer.PRESERVE)).thenReturn(true);
|
||||||
|
when(client.getBoostedSkillLevel(Skill.PRAYER)).thenReturn(99);
|
||||||
|
when(client.getItemContainer(InventoryID.EQUIPMENT)).thenReturn(itemContainer);
|
||||||
|
|
||||||
|
prayerPlugin.onItemContainerChanged(new ItemContainerChanged(InventoryID.EQUIPMENT.getId(), itemContainer));
|
||||||
|
|
||||||
|
assertEquals("79m", prayerPlugin.getEstimatedTimeRemaining(true));
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user