I'm fairly new to Subversion. Most of my work so far has been with Visual Source Safe. I'm looking to improve my deployment process with SVN and TeamCity. This is my plan:
There would be three branches:
- Development (/trunk) - Entire ASP.NET solution, including a Web Deployment Project.
- Staging (/branches/staging) - Web Deployment Project output (files needed for execution only - bin, .aspx, images, etc)
- Deployment (/branches/deployment) - same as Staging
The CI process:
- Commit source changes in trunk.
- TeamCity detects the change, builds the solution and runs unit tests.
- If all tests pass, TeamCity commits Web Deployment Project output to branches/staging and exports it to wwwroot on the staging web server.
Then when I'm ready to deploy to production, I'll do the following manually:
- Merge branches/staging with branches/production
- Update production web server's working copy of branches/production.
Does this make sense? Is there anything that a VSS user like myself might be missing/misunderstanding in this process?