OSDN Git Service

艦隊に関する責務をShipInfoからFleetクラスに移す
[kancollesniffer/KancolleSniffer.git] / KancolleSniffer.Test / BattleTest.cs
1 // Copyright (C) 2017 Kazuhiro Fujieda <fujieda@users.osdn.me>\r
2 //\r
3 // Licensed under the Apache License, Version 2.0 (the "License");\r
4 // you may not use this file except in compliance with the License.\r
5 // You may obtain a copy of the License at\r
6 //\r
7 //    http://www.apache.org/licenses/LICENSE-2.0\r
8 //\r
9 // Unless required by applicable law or agreed to in writing, software\r
10 // distributed under the License is distributed on an "AS IS" BASIS,\r
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
12 // See the License for the specific language governing permissions and\r
13 // limitations under the License.\r
14 \r
15 using System;\r
16 using ExpressionToCodeLib;\r
17 using Microsoft.VisualStudio.TestTools.UnitTesting;\r
18 \r
19 namespace KancolleSniffer.Test\r
20 {\r
21     [TestClass]\r
22     public class BattleTest\r
23     {\r
24         private ItemInfo _itemInfo;\r
25         private ShipInfo _shipInfo;\r
26         private BattleInfo _battleInfo;\r
27 \r
28         private string[] ReadAllLines(string log)\r
29         {\r
30             using (var logfile = SnifferTest.OpenLogFile(log))\r
31                 return logfile.ReadToEnd().Split(new [] {"\r\n"}, StringSplitOptions.None);\r
32         }\r
33 \r
34         [TestInitialize]\r
35         public void Initialize()\r
36         {\r
37             _itemInfo = new ItemInfo();\r
38             _shipInfo = new ShipInfo(_itemInfo);\r
39             _battleInfo = new BattleInfo(_shipInfo, _itemInfo);\r
40         }\r
41 \r
42         /// <summary>\r
43         /// 連撃を受けて女神が発動する\r
44         /// </summary>\r
45         [TestMethod]\r
46         public void CauseRepairGoddessByDoubleAttack()\r
47         {\r
48             var logs = ReadAllLines("damecon_001");\r
49             var items = JsonParser.Parse("[[[],[],[],[],[43]]]");\r
50             dynamic battle = JsonParser.Parse(logs[2]);\r
51             _shipInfo.InjectShips(battle, items);\r
52             _battleInfo.InspectBattle(logs[0], logs[1], battle);\r
53             dynamic result = JsonParser.Parse(logs[5]);\r
54             _battleInfo.InspectBattleResult(result);\r
55             PAssert.That(() => _shipInfo.Fleets[2].Ships[4].NowHp == 31);\r
56         }\r
57 \r
58         /// <summary>\r
59         /// 夜戦で戦艦の攻撃を受ける\r
60         /// </summary>\r
61         [TestMethod]\r
62         public void AttackedByBattleShipInMidnight()\r
63         {\r
64             var logs = ReadAllLines("midnight_002");\r
65             var battle = JsonParser.Parse(logs[3]);\r
66             _shipInfo.InjectShips(battle, JsonParser.Parse(logs[0]));\r
67             _battleInfo.InspectBattle(logs[1], logs[2], battle);\r
68             _battleInfo.InspectBattleResult(JsonParser.Parse(logs[6]));\r
69             PAssert.That(() => _shipInfo.Fleets[0].Ships[3].NowHp == 12);\r
70         }\r
71 \r
72         private dynamic Data(string json) => ((dynamic)JsonParser.Parse(json)).api_data;\r
73 \r
74         /// <summary>\r
75         /// NPC友軍の支援攻撃がある\r
76         /// </summary>\r
77         [TestMethod]\r
78         public void NpcFriendFleetAttack()\r
79         {\r
80             var logs = ReadAllLines("friendfleet_001");\r
81             var battle = Data(logs[3]);\r
82             _shipInfo.InjectShips(battle, JsonParser.Parse(logs[0]));\r
83             _battleInfo.InspectBattle(logs[1], logs[2], battle);\r
84             _battleInfo.InspectBattle(logs[4], logs[5], Data(logs[6]));\r
85             _battleInfo.InspectBattleResult(Data(logs[9]));\r
86             PAssert.That(() => !_battleInfo.DisplayedResultRank.IsError);\r
87         }\r
88 \r
89         /// <summary>\r
90         /// 空襲戦で轟沈する\r
91         /// </summary>\r
92         [TestMethod]\r
93         public void LdAirbattleHaveSunkenShip()\r
94         {\r
95             var logs = ReadAllLines("ld_airbattle_001");\r
96             var battle = Data(logs[3]);\r
97             _shipInfo.InjectShips(battle, JsonParser.Parse(logs[0]));\r
98             _battleInfo.InspectBattle(logs[1], logs[2], battle);\r
99             _battleInfo.InspectBattleResult(Data(logs[6]));\r
100             PAssert.That(() => !_battleInfo.DisplayedResultRank.IsError);\r
101         }\r
102 \r
103         /// <summary>\r
104         /// 空襲戦で女神が発動して復活する\r
105         /// </summary>\r
106         [TestMethod]\r
107         public void LdAirbattleHaveRevivedShip()\r
108         {\r
109             var logs = ReadAllLines("ld_airbattle_002");\r
110             var battle = Data(logs[3]);\r
111             _shipInfo.InjectShips(battle, JsonParser.Parse(logs[0]));\r
112             _battleInfo.InspectBattle(logs[1], logs[2], battle);\r
113             _battleInfo.InspectBattleResult(Data(logs[6]));\r
114             PAssert.That(() => !_battleInfo.DisplayedResultRank.IsError);\r
115         }\r
116 \r
117         /// <summary>\r
118         /// 機動対敵連合の雷撃戦でダメコンが発動する\r
119         /// </summary>\r
120         [TestMethod]\r
121         public void TreiggerDameconInCombinedBattle()\r
122         {\r
123             var logs = ReadAllLines("damecon_002");\r
124             var battle = Data(logs[3]);\r
125             _shipInfo.InjectShips(battle, JsonParser.Parse(logs[0]));\r
126             _battleInfo.InspectBattle(logs[1], logs[2], battle);\r
127             _battleInfo.InspectBattle(logs[4], logs[5], Data(logs[6]));\r
128             _battleInfo.InspectBattleResult(Data(logs[9]));\r
129             PAssert.That(() => !_battleInfo.DisplayedResultRank.IsError);\r
130         }\r
131     }\r
132 }