package controllers import com.alexitc.playsonify.PublicErrorRenderer import com.alexitc.playsonify.core.FutureApplicationResult import com.xsn.explorer.errors.AddressFormatError import com.xsn.explorer.helpers.{DataHelper, DummyXSNService} import com.xsn.explorer.models._ import com.xsn.explorer.models.rpc.AddressBalance import com.xsn.explorer.services.XSNService import controllers.common.MyAPISpec import org.scalactic.{One, Or} import play.api.inject.bind import play.api.libs.json.JsValue import play.api.test.Helpers._ import scala.concurrent.Future class AddressesControllerSpec extends MyAPISpec { import DataHelper._ val addressEmpty = createAddressDetails(0, 0, List()) val addressFilled = createAddressDetails( 100, 200, List( createTransactionId("0834641a7d30d8a2d2b451617599670445ee94ed7736e146c13be260c576c641"), createTransactionId("024aba1d535cfe5dd3ea465d46a828a57b00e1df012d7a2d158e0f7484173f7c") ) ) val customXSNService = new DummyXSNService { val map = Map( "Xi3sQfMQsy2CzMZTrnKW6HFGp1VqFThdLw" -> addressEmpty, "XnH3bC9NruJ4wnu4Dgi8F3wemmJtcxpKp6" -> addressFilled ) override def getAddressBalance(address: Address): FutureApplicationResult[AddressBalance] = { val maybe = map.get(address.string).map(_.balance) val result = Or.from(maybe, One(AddressFormatError)) Future.successful(result) } override def getTransactions(address: Address): FutureApplicationResult[List[TransactionId]] = { val maybe = map.get(address.string).map(_.transactions) val result = Or.from(maybe, One(AddressFormatError)) Future.successful(result) } } override val application = guiceApplicationBuilder .overrides(bind[XSNService].to(customXSNService)) .build() "GET /addresses/:address" should { def url(address: String) = s"/addresses/$address" "retrieve address information" in { val address = addressFilled val response = GET(url("XnH3bC9NruJ4wnu4Dgi8F3wemmJtcxpKp6")) status(response) mustEqual OK val json = contentAsJson(response) (json \ "balance").as[BigDecimal] mustEqual address.balance.balance (json \ "received").as[BigDecimal] mustEqual address.balance.received (json \ "transactions").as[List[String]].size mustEqual address.transactions.size } "fail on bad address format" in { val address = "XnH3bC9NruJ4wnu4Dgi8F3wemmJtcxpKp" val response = GET(url(address)) status(response) mustEqual BAD_REQUEST val json = contentAsJson(response) val errorList = (json \ "errors").as[List[JsValue]] errorList.size mustEqual 1 val error = errorList.head (error \ "type").as[String] mustEqual PublicErrorRenderer.FieldValidationErrorType (error \ "field").as[String] mustEqual "address" } } }