OSDN Git Service

装備解除後近代化改修で外れた装備がカウントされないのを直す
[kancollesniffer/KancolleSniffer.git] / KancolleSniffer.Test / SnifferTest.cs
index fa7050f..45a35ff 100644 (file)
@@ -89,9 +89,9 @@ namespace KancolleSniffer.Test
             var sniffer = new Sniffer();\r
             SniffLogFile(sniffer, "fighterpower_001");\r
             var fleet = sniffer.Fleets[0];\r
-            PAssert.That(() => fleet.FighterPower.SequenceEqual(new[] {156, 159}));\r
+            PAssert.That(() => fleet.FighterPower == new Range(156, 159));\r
             SniffLogFile(sniffer, "fighterpower_002");\r
-            PAssert.That(() => fleet.FighterPower.SequenceEqual(new[] {140, 143}), "全滅したスロットがある");\r
+            PAssert.That(() => fleet.FighterPower == new Range(140, 143), "全滅したスロットがある");\r
         }\r
 \r
         /// <summary>\r
@@ -102,20 +102,20 @@ namespace KancolleSniffer.Test
         {\r
             var sniffer = new Sniffer();\r
             SniffLogFile(sniffer, "fighterpower_003");\r
-            PAssert.That(() => sniffer.Fleets[0].FighterPower.SequenceEqual(new[] {135, 135}));\r
+            PAssert.That(() => sniffer.Fleets[0].FighterPower == new Range(135, 135));\r
         }\r
 \r
         /// <summary>\r
         /// 基地航空隊の制空値を正しく計算する\r
         /// </summary>\r
         [TestMethod]\r
-        public void FighterPowerOfBaseAirCorps()\r
+        public void FighterPowerOfAirBase()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "baseaircorps_001");\r
-            PAssert.That(() => sniffer.BaseAirCorps[0].AirCorps[0].FighterPower.AirCombat[1] == 301);\r
-            sniffer.BaseAirCorps[0].AirCorps[0].Action = 2; // 防空\r
-            PAssert.That(() => sniffer.BaseAirCorps[0].AirCorps[0].FighterPower.Interception[1] == 320);\r
+            SniffLogFile(sniffer, "airbase_001");\r
+            PAssert.That(() => sniffer.AirBase[0].AirCorps[0].CalcFighterPower().AirCombat.Max == 301);\r
+            sniffer.AirBase[0].AirCorps[0].Action = 2; // 防空\r
+            PAssert.That(() => sniffer.AirBase[0].AirCorps[0].CalcFighterPower().Interception.Max == 320);\r
         }\r
 \r
         /// <summary>\r
@@ -125,8 +125,8 @@ namespace KancolleSniffer.Test
         public void FighterPowerWithReconBonus()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "baseaircorps_002");\r
-            PAssert.That(() => sniffer.BaseAirCorps[0].AirCorps[2].FighterPower.Interception[0] == 353);\r
+            SniffLogFile(sniffer, "airbase_002");\r
+            PAssert.That(() => sniffer.AirBase[0].AirCorps[2].CalcFighterPower().Interception.Min == 353);\r
         }\r
 \r
         /// <summary>\r
@@ -136,19 +136,19 @@ namespace KancolleSniffer.Test
         public void FighterPowerOfLandBasedAttackAircraft()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "baseaircorps_003");\r
-            PAssert.That(() => sniffer.BaseAirCorps[1].AirCorps[0].FighterPower.AirCombat[0] == 121);\r
+            SniffLogFile(sniffer, "airbase_003");\r
+            PAssert.That(() => sniffer.AirBase[1].AirCorps[0].CalcFighterPower().AirCombat.Min == 121);\r
         }\r
 \r
         /// <summary>\r
         /// 基地航空隊の出撃コストを計算する\r
         /// </summary>\r
         [TestMethod]\r
-        public void CostForSortieOfBaseAirCorps()\r
+        public void CostForSortieOfAirBase()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "baseaircorps_003");\r
-            PAssert.That(() => sniffer.BaseAirCorps[1].AirCorps[0].CostForSortie.SequenceEqual(new[] {99, 47}));\r
+            SniffLogFile(sniffer, "airbase_003");\r
+            PAssert.That(() => sniffer.AirBase[1].AirCorps[0].CostForSortie.SequenceEqual(new[] {99, 47}));\r
         }\r
 \r
         /// <summary>\r
@@ -158,8 +158,28 @@ namespace KancolleSniffer.Test
         public void FighterPowerOfLandBAseFighter()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "baseaircorps_004");\r
-            PAssert.That(() => sniffer.BaseAirCorps[1].AirCorps[0].FighterPower.AirCombat[0] == 328);\r
+            SniffLogFile(sniffer, "airbase_004");\r
+            PAssert.That(() => sniffer.AirBase[1].AirCorps[0].CalcFighterPower().AirCombat.Min == 328);\r
+        }\r
+\r
+        /// <summary>\r
+        /// 陸上偵察機の効果を反映した制空値を計算する\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void FighterPowerWithLandBaseReconBonus()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "airbase_005");\r
+\r
+            // 二式陸上偵察機(熟練)\r
+            var fp1 = sniffer.AirBase[0].AirCorps[0].CalcFighterPower();\r
+            PAssert.That(() => fp1.AirCombat.Min == 274);\r
+            PAssert.That(() => fp1.Interception.Min == 302);\r
+\r
+            // 二式陸上偵察機\r
+            var fp3 = sniffer.AirBase[0].AirCorps[2].CalcFighterPower();\r
+            PAssert.That(() => fp3.AirCombat.Min == 206);\r
+            PAssert.That(() => fp3.Interception.Min == 310);\r
         }\r
 \r
         /// <summary>\r
@@ -290,6 +310,25 @@ namespace KancolleSniffer.Test
         }\r
 \r
         /// <summary>\r
+        /// 夜戦発動率を計算する\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void NightContactTriggerRate()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "nightrecon_001");\r
+            PAssert.That(() => Abs(sniffer.Fleets[0].NightContactTriggerRate - 84.64) < 0.01);\r
+            var ship = sniffer.Fleets[0].Ships[0];\r
+            var empty = Enumerable.Repeat(new ItemStatus(), 5).ToArray();\r
+            var orig = ship.Slot;\r
+            ship.Slot = empty;\r
+            PAssert.That(() => Abs(sniffer.Fleets[0].NightContactTriggerRate - 52) < 0.01);\r
+            ship.Slot = orig;\r
+            sniffer.Fleets[0].Ships[1].Slot = empty;\r
+            PAssert.That(() => Abs(sniffer.Fleets[0].NightContactTriggerRate - 68) < 0.01);\r
+        }\r
+\r
+        /// <summary>\r
         /// 編成で空き番号を使ったローテートを正しく反映する\r
         /// </summary>\r
         [TestMethod]\r
@@ -374,15 +413,15 @@ namespace KancolleSniffer.Test
         }\r
 \r
         /// <summary>\r
-        /// 装備の交換を正しく反映する\r
+        /// 装備交換のAPIの仕様変更に対応する\r
         /// </summary>\r
         [TestMethod]\r
-        public void SlotExchange()\r
+        public void SlotExchangeVersion2()\r
         {\r
             var sniffer = new Sniffer();\r
-            SniffLogFile(sniffer, "slot_exchange_001");\r
+            SniffLogFile(sniffer, "slot_exchange_002");\r
             var result = sniffer.Fleets[0].Ships[0].Slot.Select(item => item.Id);\r
-            PAssert.That(() => new[] {26096, 30571, 77694, 61383, -1}.SequenceEqual(result));\r
+            PAssert.That(() => new[] {157798, 59001, 157804, -1, -1}.SequenceEqual(result));\r
         }\r
 \r
         /// <summary>\r
@@ -397,6 +436,18 @@ namespace KancolleSniffer.Test
         }\r
 \r
         /// <summary>\r
+        /// 近代化改修による艦娘数と装備数の変化\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void PowerUpCount()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "powerup_001");\r
+            PAssert.That(() => sniffer.ShipCounter.Now == 204);\r
+            PAssert.That(() => sniffer.ItemCounter.Now == 932);\r
+        }\r
+\r
+        /// <summary>\r
         /// 近代化改修が二重に行われた場合に対応する\r
         /// </summary>\r
         [TestMethod]\r
@@ -408,6 +459,18 @@ namespace KancolleSniffer.Test
         }\r
 \r
         /// <summary>\r
+        /// 装備解除後の近代化改修\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void PowerUpDetachItem()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "powerup_003");\r
+            PAssert.That(() => sniffer.ShipCounter.Now == 317);\r
+            PAssert.That(() => sniffer.ItemCounter.Now == 1390);\r
+        }\r
+\r
+        /// <summary>\r
         /// ship2を待たずにケッコンの結果を反映する\r
         /// </summary>\r
         [TestMethod]\r
@@ -436,12 +499,16 @@ namespace KancolleSniffer.Test
         [TestMethod]\r
         public void CountItem()\r
         {\r
-            var sniffer1 = new Sniffer();\r
-            SniffLogFile(sniffer1, "createitem_001");\r
-            PAssert.That(() => sniffer1.ItemCounter.Now == 900);\r
-            var sniffer2 = new Sniffer();\r
-            SniffLogFile(sniffer2, "createship_001");\r
-            PAssert.That(() => sniffer2.ItemCounter.Now == 904);\r
+            var createItems = new Sniffer();\r
+            SniffLogFile(createItems, "createitem_001");\r
+            Assert.AreEqual(900, createItems.ItemCounter.Now);\r
+            PAssert.That(() => createItems.ItemCounter.Now == 900);\r
+            var createShips = new Sniffer();\r
+            SniffLogFile(createShips, "createship_001");\r
+            Assert.AreEqual(904, createShips.ItemCounter.Now);\r
+            var multiItems = new Sniffer();\r
+            SniffLogFile(multiItems, "createitem_002");\r
+            Assert.AreEqual(1307, multiItems.ItemCounter.Now);\r
         }\r
 \r
         /// <summary>\r
@@ -633,8 +700,7 @@ namespace KancolleSniffer.Test
         {\r
             var sniffer = new Sniffer(true);\r
             SniffLogFile(sniffer, "twofleets_001");\r
-            var expected = Enumerable.Repeat(new ChargeStatus(5, 5), ShipInfo.FleetCount);\r
-            PAssert.That(() => expected.SequenceEqual(sniffer.Fleets.Select(f => f.ChargeStatus)));\r
+            PAssert.That(() => new[]{5, 5, 0, 0}.SequenceEqual(sniffer.Fleets.Select(f => f.ChargeStatus.Fuel)));\r
         }\r
 \r
         /// <summary>\r
@@ -721,11 +787,60 @@ namespace KancolleSniffer.Test
             SniffLogFile(sniffer, "mapgauge_001");\r
             PAssert.That(() =>\r
                 sniffer.MiscText ==\r
-                               "[海域ゲージ]\r\n" +\r
-                               "1-6 : 残り 5/7\r\n" +\r
-                               "2-5 : 残り 4/4\r\n" +\r
-                               "3-5 : 残り 4/4\r\n" +\r
-                               "4-4 : 残り 4/4\r\n");\r
+                "[海域ゲージ]\r\n" +\r
+                "1-6 : 残り 5/7\r\n" +\r
+                "2-5 : 残り 4/4\r\n" +\r
+                "3-5 : 残り 4/4\r\n" +\r
+                "4-4 : 残り 4/4\r\n");\r
+        }\r
+\r
+        /// <summary>\r
+        /// 7-2の2本目の海域ゲージを正しく表示する\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void SecondAreaGauge()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "mapgauge_002");\r
+            PAssert.That(() =>\r
+                sniffer.MiscText ==\r
+                "[海域ゲージ]\r\n" +\r
+                "1-6 : 残り 5/7\r\n" +\r
+                "2-5 : 残り 2/4\r\n" +\r
+                "5-5 : 残り 5/5\r\n" +\r
+                "6-5 : 残り 6/6\r\n" +\r
+                "7-2 : 残り 1/4\r\n");\r
+        }\r
+\r
+        /// <summary>\r
+        /// 2019冬イベからクリア済みマップのゲージ情報がない\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void ClearedExMapGage()\r
+        {\r
+            var miscTextInfo = new MiscTextInfo(null, null);\r
+            using (var stream = OpenLogFile("mapgauge_003"))\r
+            {\r
+                miscTextInfo.InspectMapInfo(JsonParser.Parse(stream.ReadToEnd()));\r
+            }\r
+            PAssert.That(() =>\r
+                miscTextInfo.Text ==\r
+                "[海域ゲージ]\r\n" +\r
+                "1-6 : 残り 5/7\r\n" +\r
+                "5-5 : 残り 5/5\r\n" +\r
+                "7-2 : 残り 1/4\r\n" +\r
+                "43-2 : HP 1050/1400\r\n");\r
+        }\r
+\r
+        /// <summary>\r
+        /// 演習の獲得経験値を計算する\r
+        /// </summary>\r
+        [TestMethod]\r
+        public void PracticeExpPoint()\r
+        {\r
+            var sniffer = new Sniffer();\r
+            SniffLogFile(sniffer, "practice_004");\r
+            PAssert.That(() => sniffer.MiscText == "[演習情報]\r\n敵艦隊名 : 第一艦隊\r\n獲得経験値 : 878\r\nS勝利 : 1053");\r
         }\r
 \r
         /// <summary>\r