Я делаю что-то, что мне кажется простым, но одним шагом мне нужно сделать что-то довольно хакерское, поэтому я предполагаю, что есть лучший способ. У меня есть набор лямбд AWS (в Java, но это, вероятно, не имеет значения), которые я хочу поместить в CI / CD. Итак, теперь у меня есть один репозиторий codecommit с исходным кодом;У меня есть работа по сборке кода, которая создает их и обновляет гамма-версию лямбды. Затем у меня есть еще одно репозиторий codecommit с интеграционными тестами и задание сборки кода, которое создает тесты и запускает их (и не может создать, если тесты не пройдены). Я связал их вместе с codepipeline, и все хорошо!
За исключением того, что если тесты пройдут, я хочу автоматически обновить код функции prod lambda. Единственный способ сделать это - выполнить еще одно третье задание по сборке кода, а затем запустить buildspec.yml, который не выполняет ничего, кроме запуска «aws lambda update-function-code». Кажется, действительно неправильно запускать целую кодовую сборку только для этого. Есть ли способ в codepipeline просто напрямую обновить код лямбда-функции с одним из артефактов в конвейере?
Я вижу, что я могу поместить облачную информацию в конвейер, но похоже, что она нуждается в новой облачной информациифайл - я не хочу обновлять формирование или лямбда-конфигурацию, просто код.