Контролируемая интеграция изменений с непрерывной интеграцией
У меня есть установщик NSIS, который мы ранее создали с помощью сценариев nAnt, которые копируют некоторые файлы и запускают makensis.exe через задачу exec для создания exe установщика. После завершения сценария nant у меня есть структура compelte для нашего CD, а также наша загрузка.
Я просто делал переход с SourceSafe на неиспользуемый рабочий стол и использовал его в качестве сборки для компиляции. Иногда в этом исправлении мы проверяли пару файлов, что-то критичное. В этих случаях я бы пошел в окно сборки и очень избирательно получал только эти файлы, чтобы избежать получения других измененных файлов, которые мы еще не готовы выпустить. По сути, я могу позволить продолжить разработку и выборочно включать определенные измененные файлы в установщик для выпуска.
Теперь у нас больше нет бесплатного ящика, и нам нужно собрать его с нашего сервера. Поэтому я настраиваю CI Factory так, чтобы разработчик мог запустить сборку без удаленного взаимодействия с сервером. Единственная проблема, с которой я борюсь, - это лучший способ и впредь позволять этому избирательному контролю изменений происходить. Концепция по умолчанию CI, которую реализует CI Factory, подходит для внутреннего развития. Тем не менее, я также хочу настроить проект CCNet, который запускается только по запросу через Force Build для этого типа "публичного выпуска".
Это то, о чем я до сих пор штурмовал, не зная, насколько хорошо это будет работать, если вообще будет (все еще выясняя, что такое CCNet и CI Factory). Конфигурация / сборка проекта CCNet "публичного выпуска" будет настроена таким образом, что она не будет последней. Модификации не будут вызывать сборку. Поскольку другой проект CCNet, использующий методологию CI по умолчанию (мы будем называть его "проектом CI"), получает последние данные при обнаружении изменений, тогда эти два проекта не могут использовать один и тот же рабочий каталог. Поэтому для "публичного релиза" потребуется другая рабочая копия, чтобы его файлы не обновлялись при запуске сборки CI-проекта. Разработчику потребуется удаленно подключиться к серверу, одному VSS, выборочно получить рабочую копию "публичного релиза", а затем форсировать сборку с помощью CI Factory.
Недостаток, который я вижу с этим
1) Дистанционно, чтобы выборочно сделать получает.
2) Я понятия не имею, как разрешить одному проекту CI Factory иметь две разные рабочие копии папки Product, чтобы у каждого блока конфигурации проекта была своя собственная.
3) Я боюсь какой странности это может вызвать. Я еще не совсем уверен, как указать блок управления исходным кодом в блоке конфигурации проекта CCNet, но мешаю ему получить последнюю версию при сборке. Я все еще постепенно выясняю, что находится в сценариях, и что его можно легко убрать, не ломая другие вещи, в отличие от того, что не должно быть изменено и / или не настраивается.
Мне бы очень хотелось услышать о том, как другие решают проблему выборочного выпуска изменений, если у вас похожая ситуация. Я ограничен VSS, поэтому моя непосредственная потребность - решить это с учетом этого, но в то же время мне было бы интересно услышать, как вы управляете этим с другими системами контроля версий. Я предполагаю, что у вас, вероятно, будет ветка, которая является вашей последней веткой разработок, и затем сливать изменения в ствол всякий раз, когда вы хотите выпустить их? Я действительно не доверяю VSS для ветвления / слияния, и я думаю, что концепции ветвления могут быть слишком большими накладными расходами и кривой обучения для этого магазина. Как я уже сказал, истории с другими системами контроля версий будут полезны для меня в будущем.
Заранее спасибо.
1 ответ
Вам нужна ветвящаяся структура в вашем хранилище, чтобы облегчить это. Что-то вроде метода веток релиза. Только отдельные лица могут фиксировать эту ветку (или иметь релиз / стабильную версию для этого). Настройте свои ручные запуски CI так, чтобы они вытягивались из ветки релиза, а выпуск оттуда переходил ночью к финальному этапу или финалу. Мне не нравится идея ручного изменения вещей на вашей сборочной машине. Настройте изменения в управлении версиями в безопасном месте, чтобы подготовить свой выпуск и позволить CI строить оттуда, но запускаться вручную.
Проверьте эти шаблоны ветвления. Я предложил C3, codeline-per-release, часто называемый ветвлением релиза.
Вот статья о ветвлении VSS, в которой есть ссылка на слияние.
Этот вопрос выглядит похоже.
Может быть, вы могли бы перейти на другую систему контроля версий с лучшей поддержкой для такого рода вещей. Какие-нибудь предложения от людей MS там?