1 // Copyright (C) 2017 Kazuhiro Fujieda <fujieda@users.osdn.me>
\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
7 // http://www.apache.org/licenses/LICENSE-2.0
\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
16 using ExpressionToCodeLib;
\r
17 using Microsoft.VisualStudio.TestTools.UnitTesting;
\r
19 namespace KancolleSniffer.Test
\r
22 public class BattleTest
\r
24 private ItemInfo _itemInfo;
\r
25 private ShipInfo _shipInfo;
\r
26 private BattleInfo _battleInfo;
\r
28 private string[] ReadAllLines(string log)
\r
30 using (var logfile = SnifferTest.OpenLogFile(log))
\r
31 return logfile.ReadToEnd().Split(new [] {"\r\n"}, StringSplitOptions.None);
\r
35 public void Initialize()
\r
37 _itemInfo = new ItemInfo();
\r
38 _shipInfo = new ShipInfo(new ShipMaster(), _itemInfo);
\r
39 _battleInfo = new BattleInfo(_shipInfo, _itemInfo);
\r
46 public void CauseRepairGoddessByDoubleAttack()
\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
62 public void AttackedByBattleShipInMidnight()
\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
72 private dynamic Data(string json) => ((dynamic)JsonParser.Parse(json)).api_data;
\r
78 public void NpcFriendFleetAttack()
\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
93 public void LdAirbattleHaveSunkenShip()
\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
104 /// 空襲戦で女神が発動して復活する
\r
107 public void LdAirbattleHaveRevivedShip()
\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
118 /// 機動対敵連合の雷撃戦でダメコンが発動する
\r
121 public void TreiggerDameconInCombinedBattle()
\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