added tests for: VoiceHost*, CharacterInfoMessage, CharacterCreateRequestMessage, CharacterRequestMessage, and KeepAliveMessage; modified test for ObjectDetectedMessage

This commit is contained in:
FateJH 2017-05-03 19:48:23 -04:00
parent 461a4f9507
commit 939e0ed688
12 changed files with 257 additions and 39 deletions

View file

@ -0,0 +1,33 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import net.psforever.types.{CharacterGender, PlanetSideEmpire}
import scodec.bits._
class CharacterCreateRequestMessageTest extends Specification {
val string = hex"2f 88 54006500730074004300680061007200 320590"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case CharacterCreateRequestMessage(name, head, voice, gender, faction) =>
name mustEqual "TestChar"
head mustEqual 50
voice mustEqual 5
gender mustEqual CharacterGender.Female
faction mustEqual PlanetSideEmpire.NC
case _ =>
ko
}
}
"encode" in {
val msg = CharacterCreateRequestMessage("TestChar", 50, 5, CharacterGender.Female, PlanetSideEmpire.NC)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}

View file

@ -0,0 +1,32 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class CharacterInfoMessageTest extends Specification {
val string = hex"14 0F000000 10270000C1D87A024B00265CB08000"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case CharacterInfoMessage(unk, zone, charId, guid, finished, last) =>
unk mustEqual 15L
zone mustEqual PlanetSideZoneID(10000)
charId mustEqual 41605313L
guid mustEqual PlanetSideGUID(75)
finished mustEqual false
last mustEqual 6404428L
case _ =>
ko
}
}
"encode" in {
val msg = CharacterInfoMessage(15L, PlanetSideZoneID(10000), 41605313L, PlanetSideGUID(75), false, 6404428L)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}

View file

@ -0,0 +1,30 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import net.psforever.types.{CharacterGender, PlanetSideEmpire}
import scodec.bits._
class CharacterRequestMessageTest extends Specification {
val string = hex"30 c1d87a02 00000000"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case CharacterRequestMessage(charId, action) =>
charId mustEqual 41605313L
action mustEqual CharacterRequestAction.Select
case _ =>
ko
}
}
"encode" in {
val msg = CharacterRequestMessage(41605313L, CharacterRequestAction.Select)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}

View file

@ -0,0 +1,28 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class KeepAliveMessageTest extends Specification {
val string = hex"BA 0000"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case KeepAliveMessage(code) =>
code mustEqual 0
case _ =>
ko
}
}
"encode" in {
val msg = KeepAliveMessage()
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}

View file

@ -11,25 +11,37 @@ class ObjectDetectedMessageTest extends Specification {
"decode" in {
PacketCoding.DecodePacket(string).require match {
case ObjectDetectedMessage(guid1, guid2, unk1, unk2) =>
case ObjectDetectedMessage(guid1, guid2, unk1, list) =>
guid1 mustEqual PlanetSideGUID(4070)
guid2 mustEqual PlanetSideGUID(4070)
unk1 mustEqual 0
unk2.size mustEqual 7
unk2.head mustEqual 3623
unk2(1) mustEqual 3198
unk2(2) mustEqual 3088
unk2(3) mustEqual 1579
unk2(4) mustEqual 1578
unk2(5) mustEqual 3341
unk2(6) mustEqual 2997
list.size mustEqual 7
list.head mustEqual PlanetSideGUID(3623)
list(1) mustEqual PlanetSideGUID(3198)
list(2) mustEqual PlanetSideGUID(3088)
list(3) mustEqual PlanetSideGUID(1579)
list(4) mustEqual PlanetSideGUID(1578)
list(5) mustEqual PlanetSideGUID(3341)
list(6) mustEqual PlanetSideGUID(2997)
case _ =>
ko
}
}
"encode" in {
val msg = ObjectDetectedMessage(PlanetSideGUID(4070), PlanetSideGUID(4070), 0, 3623 :: 3198 :: 3088 :: 1579 :: 1578 :: 3341 :: 2997 :: Nil)
val msg = ObjectDetectedMessage(
PlanetSideGUID(4070),
PlanetSideGUID(4070),
0,
PlanetSideGUID(3623) ::
PlanetSideGUID(3198) ::
PlanetSideGUID(3088) ::
PlanetSideGUID(1579) ::
PlanetSideGUID(1578) ::
PlanetSideGUID(3341) ::
PlanetSideGUID(2997) ::
Nil
)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string

View file

@ -0,0 +1,27 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class VoiceHostInfoTest extends Specification {
val string_info = hex"b2 4b00"
"decode" in {
PacketCoding.DecodePacket(string_info).require match {
case VoiceHostInfo(player, _) =>
player mustEqual PlanetSideGUID(75)
case _ =>
ko
}
}
"encode" in {
val msg = VoiceHostInfo(PlanetSideGUID(75), ByteVector.empty)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string_info
}
}

View file

@ -0,0 +1,27 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class VoiceHostKillTest extends Specification {
val string_kill = hex"b1"
"decode" in {
PacketCoding.DecodePacket(string_kill).require match {
case VoiceHostKill() =>
ok
case _ =>
ko
}
}
"encode" in {
val msg = VoiceHostKill()
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string_kill
}
}

View file

@ -0,0 +1,28 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import scodec.bits._
class VoiceHostRequestTest extends Specification {
val string_request = hex"b0 2580 00"
"decode" in {
PacketCoding.DecodePacket(string_request).require match {
case VoiceHostRequest(unk, player, _) =>
unk mustEqual false
player mustEqual PlanetSideGUID(75)
case _ =>
ko
}
}
"encode" in {
val msg = VoiceHostRequest(false, PlanetSideGUID(75), ByteVector.empty)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string_request
}
}