Тестирование блока контроллера покоя с пружинной загрузкой, котлин и джунит - PullRequest
0 голосов
/ 07 мая 2018

В настоящее время я разрабатываю веб-сайт с весенней загрузкой, где я стараюсь читать RSS-каналы Google Trends в формате xml и анализировать их для Json. Я хочу добавить модульные тесты для тестирования моего контроллера, но я не знаю, что именно тестировать.

Это мой класс данных:

data class Rss (

    val title: String,
    val source: String,
    val image: String,
    val description: String,
    val url: String
)

Это мой покой Контроллер

@RestController
@RequestMapping(value="/rss")
class RssRestService {

   @GetMapping(value = "/list/item")
   @CrossOrigin("http://localhost:3000")
   fun rss(): List<Rss>? {

         val url = "https://trends.google.fr/trends/hottrends/atom/feed?pn=p1"
         val reader = XmlReader(URL(url))
         val feed: SyndFeed = SyndFeedInput().build(reader)
         return feed.entries.subList(1,6)
                 .map { entry -> Rss(
                 title = entry.title,
                 image = entry.foreignMarkup[1].content[0].value.substring(2),
                 source = entry.foreignMarkup[2].content[0].value,
                 description = entry.foreignMarkup[3].content[1].value.toString(),
                 url = entry.foreignMarkup[3].content[1].value
    ) }

}

И что я до сих пор делал для тестирования

@RunWith(SpringRunner::class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class DemoApplicationTests {


    @Autowired
    lateinit var testRestTemplate: TestRestTemplate

    @Test
    fun contextLoads() {

    }

    @Test
    fun rssTest() {
        val result = testRestTemplate.getForEntity("/rss/list/item", String::class.java)
        Assert.assertNotNull(result)
        Assert.assertEquals(HttpStatus.OK, result.statusCode)

}

Мой вопрос: что я должен проверить? и как проверить, есть ли на выходе запись или нет?

Ответы [ 2 ]

0 голосов
/ 09 мая 2018

Я разделил контроллер из сервиса:

RestController:

@RestController
@RequestMapping(value="/rss")

class RssRestService {
    @Autowired
    lateinit var rssService: RssService


    @GetMapping(value = "/list/item")
    @CrossOrigin("http://localhost:3000")

    fun rss(): List<Rss>? {

        val url = "https://trends.google.fr/trends/hottrends/atom/feed?pn=p1"
        return  rssService.getListRss(url)

    }

Мой сервис

@Component
class RssService{

    fun getListRss(url: String): List<Rss> {
        val reader = XmlReader(URL(url))
        val feed: SyndFeed = SyndFeedInput().build(reader)
        return feed.entries.subList(1,6)
                .map { entry -> Rss(
                        title = entry.title,
                        image = entry.foreignMarkup[1].content[0].value,
                        source = entry.foreignMarkup[2].content[0].value,
                        description = entry.foreignMarkup[3].content[1].value.toString(),
                        url = entry.foreignMarkup[3].content[5].value
                ) }
    }

А затем для тестирования я создал файл со статическими RSS-каналами и передал его путь в виде URL

@Test
    fun listItemTest() {
        val result = rssService.getListRss("file:///Home/iroolApp/src/test/kotlin/com/iroolapp/demo/feeds")
        Assert.assertEquals("Iran Nuclear Deal", result[0].title)
        Assert.assertEquals("//t0.gstatic.com/images?q=tbn:ANd9GcTbU16JklJB3H_Ib3dUeu03_4HQPABuE8EthZQRUEG6JMFyDHYytTn-9wexe3E2yYOKO1K9c0Fl", result[0].image)
        Assert.assertEquals("New York Times", result[0].source)
        Assert.assertEquals("Trump Withdraws US From &#39;One-Sided&#39; <b>Iran Nuclear Deal</b>", result[0].description)
        Assert.assertEquals("https://www.nytimes.com/2018/05/08/world/middleeast/trump-iran-nuclear-deal.html", result[0].url)

    }

Так правильно ли передавать файл с локальным путем, содержащий каналы?

0 голосов
/ 08 мая 2018

Вы сильно усложнили модульное тестирование своего контроллера, поскольку он зависит от внешнего URL-адреса для получения сведений о новостных лентах.

Я бы извлек взаимодействие с внешним URL-адресом в отдельную службу, а затем автоматически связал эту службу с вашим контроллером. Это позволило бы yopu использовать импровизированную реализацию этой службы в модульных тестах для вашего контроллера, а затем вы могли бы ввести известные элементы фида и убедиться, что ответы от вашего контроллера верны.

...