169 похожих чатов

Здоровья всем! Ребят вчера накидывал тесты на munit + testcontainers-(munit|postgres) И написал

в итоге все так:
class BuildRepoImplSpec extends FunSuite with TestContainerForAll with Donors {
override val containerDef: ContainerDef = PostgreSQLContainer.Def()
implicit val executionContext: ExecutionContext =
ExecutionContext.fromExecutor(
Executors.newFixedThreadPool(10)
)

override def afterContainersStart(container: containerDef.Container): Unit = {
val postgresContainer = container.asInstanceOf[PostgreSQLContainer]
Main.migrate(
DB(
url = postgresContainer.jdbcUrl,
driver = postgresContainer.driverClassName,
user = postgresContainer.username,
password = postgresContainer.password
)
).unsafeRunSync()
}

test("create and retrieve the build") {
withContainers { container =>
val postgresContainer = container.asInstanceOf[PostgreSQLContainer] // Пришлось так делать
val db =
Database.forURL(
url = postgresContainer.jdbcUrl,
user = postgresContainer.username,
driver = postgresContainer.driverClassName,
password = postgresContainer.password
)
...
Потому что тип containerDef.Container является всего лишь:
type Container <: Startable with Stoppable
И если не кастовать то фиг достанешь параметры для создания транзактора
Есть способ без явного кастования эту проблему решить?
Дока вообще говорит что должно без кастования работать - возможно я что-то сделал не так

2 ответов

11 просмотров

Не, там же тип контейнера это абстрактный тайпмембер, который каждый деф доопределяет

Похожие вопросы

Обсуждают сегодня

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Народ, кто шарит в расширенных разделах (EBR/EPR) на дисках с разметками MBR? Везде пишут (в вики рус/англ) в частности + другие источники смотрел, что первый сектор расширенн...
Eugene Krasnikov (ᴊɪɴ x)
1
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Где-то есть статьи, как писать на OCaml после Kotlin (ну или похожей направленности)? Я привык к интерфейсам и наследованию классов, а здесь это выглядит совершенно не так.
Раскопки Майтрейи Коц
6
Продолжая диалог про свифт в проде – сейчас возник вопрос в активном наборе бекендеров. В основном в нашей компании мы фанаты Java Spring и полностью ей довольны. Однако найм ...
Guseyn
27
Карта сайта