...
Table of contents
Table of Contents |
---|
Info |
---|
Target Date: May 14, 2014 |
Tasks
Info |
---|
All dates are referenced to 12:00 noon EDT. For example, a deadline of March 15 should be interpreted as March 15, 12:00 noon EDT. |
Early Tasks
These are long-lead early tasks that can be completed before the detailed release cycle.
Use "(/)
" for the checkmark () and "(x)" for the cross ()
Internal
Status
Review Previous Build Release R2013b Process Notes
Needed by App Freeze.
Release Process Work Before next Cycle for R2015a
- NTR needs to go in months (3-6) earlier
- Define major roles and assign them to individualsbefore next release
- Proposed roles are shown below.
- Ensure those in major roles are reachable and preferably in the office during critical stages like creating and testing RCs.
- Consider merging to production and test this before next release process
- Automate installer packaging
- Consider sanity check from mission users' scripts
- Feature Freeze/QA Complete/Beta Test must happen earlier (month before code/App Freeze)
- We need to baseline the test results well before release process starts. Probably at Feature Freeze\QA Freeze
- Consider allowing GATS to produce multiple reports from one test run
- Consider feature freeze month before
- QA Complete needs to happen much earlier (month?) probably with Feature Freeze
Proposed Roles For Next Release for R2015a
- Release Manager (RM): "owns" release, initiates process, creates tracking page, sends daily status updates, tracks issues to completion, makes sure everyone gets their stuff done, brings decisions to CCB/team, maintains tracking page, collects lessons learned, documents process improvements for next release
- Build Manager (BM): controls build system, creates RCs, sends RC availability announcements
- Test Managers (TM): control GUI/script testing for each RC
Info |
---|
Target Date: May 14, 2014 |
Tasks
Info |
---|
All dates are referenced to 12:00 noon EDT. For example, a deadline of March 15 should be interpreted as March 15, 12:00 noon EDT. |
Early Tasks
These are long-lead early tasks that can be completed before the detailed release cycle.
Use "(/)
" for the checkmark () and "(x)" for the cross ()
Task | Who | Status | Internal Status | Notes |
---|---|---|---|---|
Review Previous Build Release R2013b Process Notes | All | |||
Get updated legal statement/license | SPH |
| Needed by Code Freeze. | |
Update sample scripts | SPH |
| Needed by App Freeze.
| |
Write draft Release Notes |
SPH |
| Needed by App Freeze. | |
Update standard descriptive text | SPH | Needed by App Freeze. Will be used in User Guide, websites, release announcement. | ||
Update version number on User Guide cover page | JJKP | Needed by App Freeze. Contact Katy Gammage or Mary Hrybyk-Keith. Next time: integrate sejda-console to do this automatically. | ||
Update info on public-facing websites | JJKP | N/A | Needed by Release Day. See the list of sites. Update this list as well, if necessary. Updated major sites before announcement. Minor ones can be updated a bit later. | |
Update release announcement contacts | SPH | N/A | N/A | Needed by Release Day. Located here. |
Put in order for additional icons | SPH | N/A | N/A | (if necessary) Needed by Visual Freeze. |
For QA Complete (April 21)
...
Task | Who | Status | Internal Status | Notes |
---|---|---|---|---|
Update About panel | LOJ |
| ||
Update splash screen | TGG |
| ||
Update icons | TGG | If there are any updates, additions, deletions. Including GMATIcon for Welcome Page | ||
Update gmat_startup_file.txt | JJKP |
No new plugins added. Commented out internal plugins. | ||
Switch to release configuration in script test system | JJKP |
4/30: switched to R2014aInternal 7/17: tested public release using R2014aPublic | ||
Complete visual updates | (All) | 4/30: JJKP: still waiting on final updates to contributors list from KARI 5/2: TGG: final update committed |
...
Task | Who | Status | Internal Status | Notes | ||
---|---|---|---|---|---|---|
Update EOP files | WCS | Update eopc04_08.62-now and run smoke tests. | Update files w/ updated legal statement | LOJ. | ||
Update files w/ updated legal statement | LOJ |
| ||||
Update license text | LOJ | Update application/License.txt file. | ||||
Final bug fixes | (All) | |||||
Mark all open bugs as Affects: current release | SPH |
|
| |||
Update license text | LOJ | Update application/License.txt file. | ||||
Final bug fixes | (All) | |||||
Mark all open bugs as Affects: current release | SPH |
|
...
Warning |
---|
For this release: Should we branch the repo here, instead of after release? We need to allow people to continue working on unrelated items while release work is ongoing.{warning |
Warning |
---|
(DJC here) A better approach going forward would be to merge master into production, and switch the test system to the production branch. This probably ought to be done right before building RC1. The dev team would have 2 options then:
The former is the better approach, IMO, because it ensures that the bug fix is made on the current code base for the release. |
For App Freeze (May 5)
App Freeze is a freeze on all application bundle files beyond data and code. This includes documentation, sample scripts, stuff in the extras
folder, etc.
...
Task | Who | Status | Notes | ||
---|---|---|---|---|---|
Update README.txt | JJKP | RC1: | RC1: RC2-RC5: N/A | Next time: this should probably be "Update Release Notes" to add outstanding bugs, etc. | |
Build Windows installer | JJKP (backup: TGG) RC1 | RC1: RC2: RC2-2: RC3: RC4: RC5: | Version string: R2014a-rc# Next time: build manager should do this | ||
Bundle Windows zip | JJKP (backup: TGG) RC1backup: TGG) | RC1: RC2: RC2-2: RC3: RC4: RC5: | Version string: R2014a-rc# Next time: build manager should do this | ||
Run TestComplete smoke tests | TR | RC1: | These are tests on the packaged versions of GMAT: the installer and the zip bundle. | ||
Run TestComplete system test missions | TR | RC1: | These are tests on the packaged versions of GMAT: the installer and the zip bundle. | ||
Run script test system | JJKP (backup: TGG) | RC1RC1: RC2: RC2-2: RC3: RC4: RC5: | Run the internal installer tests on T4 and the public installer tests on Joel's machine. Run .zip bundle tests afterwards on same build to compare. | ||
Test all sample scripts | SPH | RC2: RC4: | At a minimum these need to be run individually by hand. I ran them by adding the folder, and they run so fast I missed some pretty big problems. Ideally, these should all be in script regression tests. Many but not all already are regression tested. Or, we should add them to GUI regression system. | ||
Run TestComplete full regression tests | TR | RC4: RC5: | (For final RC only) |
Info | ||
---|---|---|
| ||
|
...
Task | Who | Status | Notes | |||
---|---|---|---|---|---|---|
Bundle source code and upload to SourceForge | DJC* |
| Bundle data and upload to SourceForge | DJC |
| |
Bundle data | DJC* |
| ||||
Upload source bundle to SourceForge | JJKP |
| ||||
Upload data bundle to SourceForge | JJKP |
| ||||
Upload Windows installer to SourceForge | JJKP | Download, install, and run after uploading. | ||||
Upload Windows zip to SourceForge | JJKP | Download and run after uploading. | ||||
Post README.rst.txt on SourceForge | JJKP | Update for new release | ||||
Upload docs to documentation site | JJKP |
| ||||
Post internal & public release files to MESA network | JJKP | 2014-05-22: posted internal files only; public files are in build\VS2010_build\R2014a | ||||
Branch and tag repositories | JJKPDJC | At least tag the test system; consider branching also if the burden on the repo is low. | ||||
Make SourceForge repository backup | JJKP | Follow SourceForge's instructions. Perform the backup on the Linode server and download the resultant .zip file, since the local network blocks rsync.local network blocks rsync. |
* DJC can only do steps 1-3 here because of contractual constraints
Release Day (May 14)
Use "(/)
" for the checkmark () and "(x)" for the cross ()
Task | Who | Status | Notes | ||||||
---|---|---|---|---|---|---|---|---|---|
Make files visible on SourceForge | SPHJJKP | 07/21: Made visible at time of posting, as "soft" release. | |||||||
Send out release announcement | SPH |
| |||||||
Post release announcement on SourceForge | DJCSPH* | ||||||||
Post release announcement on GMAT Blog | JJKP | Mark as released in JIRA | SPH | ||||||
Mark as released in JIRA | SPH | ||||||||
Migrate code to SourceForge repository | JJKP | Do we migrate to git at the same time? |
This needs to be assigned to a different person; DJC cannot post to SF
Post-Release
Use "(/)
" for the checkmark ().
Task | Who | Status | Notes | ||||||
---|---|---|---|---|---|---|---|---|---|
Party! | (All) |
| Print materials | JJKP | Plan for week of June 19 | ||||
Conduct postmortem review | SPH | This includes gathering feedback, holding the postmortem meeting, and documenting the results. | |||||||
Submit GSFC Metrics Summary | SPHWCS | Measurement summary tool must be submitted for each major build | The link to submit the metrics is invalid.No action is required for this item. It was decided on 09/25/14's GMAT meeting to check tasks that do not require any action or are inactive. | ||||||
Submit NTR for next release | SPH | ||||||||
Spring cleaning | ? | General cleanup of infrastructure:
| |||||||
Per Hughes: The NTR cannot be written until all features are finalized and it is too early to do that. |
Notes for postmortem
Please add your notes to the R2014a Lessons Learned document.
...
- Create the build
- Log into
gs580w-gmat-t4
as "gs580w-gmat-t4\builduser
". The credentials are on the network drive, in theInfrastructure
folder. - Start Task Scheduler.
- [RC1 only] Disable the "GMAT Daily Build" task, so it doesn't run automatically during the RC cycle (this can make things overly confusing).
- Manually run the "GMAT Daily Build" task.
- On your local system, navigate to
SourceForge\trunk\build\install\windows-nsis
. There" task.
- Log into
- Create the bundles
- On your local system, navigate to
GmatDevelopment\build\install\windows-nsis
. Note that you do not need to pull files down from the GIT repository; this process will pull files from the remote build and create the packages in your local directory. There's aREADME.txt
file there that explains things. - Open a MinGW Shell in this directory.
- Run "
make VERSION="R2014a-rc#"
", where "#
" is the number of the RC you're creating. This will create four packages in the current directory: A.zip
and a.exe
file for both the internal and public versions. Note: to create only an internal version, run "make internal VERSION="R2014a-rc#". - Copy the four package files to the network:
\\mesa-file\595\GMAT\Builds\windows\VS2010_build\R2014a
- To clean everything up afterwards, run "
make clean
".
- On your local system, navigate to
- Run the script test system on the internal installer package. See Running the script test system, below.
...