diff --git a/doc/upstream-training/index.rst b/doc/upstream-training/index.rst index cbfc97b9..e7216457 100644 --- a/doc/upstream-training/index.rst +++ b/doc/upstream-training/index.rst @@ -22,6 +22,9 @@ the project's technical tools and social interactions. In a followup session, the students benefit from individual online sessions to help them resolve any remaining problems they might have. + +:doc:`upstream-details` + When & Where to get OpenStack Upstream Training =============================================== diff --git a/doc/upstream-training/upstream-details.rst b/doc/upstream-training/upstream-details.rst new file mode 100644 index 00000000..f6489e4d --- /dev/null +++ b/doc/upstream-training/upstream-details.rst @@ -0,0 +1,299 @@ +=================================== +OpenStack Upstream Training Details +=================================== + +Introduction +============ + +With over 2000 developers from 80 different companies worldwide, OpenStack is +one of the largest collaborative software-development projects. Because of its +size, it is characterized by a huge diversity in social norms and technical +conventions. These can significantly slow down the speed at which newcomers +are successful at integrating their own roadmap into that of the OpenStack +project. + +We've designed a training program to help professional developers negotiate +this hurdle. It shows them how to ensure their bug fix or feature is accepted +in the OpenStack project in a minimum amount of time. The educational program +requires students to work on real-life bug fixes or new features during two +days of real-life classes and online mentoring, until the work is accepted by +OpenStack. The live two-day class teaches them to navigate the intricacies of +the project's technical tools and social interactions. In a followup session, +the students benefit from individual online sessions to help them resolve any +remaining problems they might have. + +Objectives +========== + +- Faster integration of the companies product roadmap into the OpenStack + release cycle +- Successfully contribute one real world patch to an OpenStack component +- Master the technical tools +- Understand the OpenStack contribution workflow and social norms + +Target Audience +=============== + +- Developers +- System administrators + +Prerequisites +============= + +- Being able to read and write English at a technical level. +- If contributing code, being technically proficient enough to carry out + simple bug fixes in the project. +- If contributing documentation, being able to produce documents in the + project's chosen infrastructure. +- Having at least 8 hours a week to dedicate to the project, be it through + programming or through interacting with the community. + +Duration +======== + +- Face-to-face section: 2 days +- Online section: 10 one-hour individual mentoring sessions over a period of + 4 to 10 weeks + +Infrastructure +============== + +- `ready to use devstack VM `_ + for participants with network connectivity but troubles with their laptop + +Course Outline +============== + +First day +========= + +Introduction +~~~~~~~~~~~~ + +* A week before Day 1: choice of a contribution, via email, with each + participant +* Day 1: How OpenStack is made +* Day 1: Learn and practice git, gerrit, IRC + +* Day 2: The theory of contribution +* Day 2: Lego contribution simulation +* Day 2: Individual presentation of the contribution plan +* Day 2: Online mentoring + +How OpenStack is made (3h including 1h30 exercises) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +* `Release cycle `_ + (`slides <01-release-cycle.html>`__) + + * `Planning (Design, Discuss and Target) `_ + * `Implementation (Milestone iterations `_ + * `Pre-release (Release Candidates dance) `_ + + * `Release candidate 1 `_ + * `Other release candidates `_ + * `Release day `_ + + * Exercise: based on the `Kilo release schedule `_ + find the URL of a document or a patch that belongs to each of the above + steps. + +* Relevant actors (`slides <02-relevant-actors.html>`__) + + * `commiters `_ + companies + * `commiters `_ + individuals (bottom of the page) + * Your management + +* `OpenStack Governance `_ + (`slides <03-technical-committee.html>`__) + + * `Technical Committee `_ + * `The role of the Technical Committee `_ + * `OpenStack Project Teams `_ + * `OpenStack Project Teams list `_ + * `Meetings `_ + * Exercise: read `archived `_ + and briefly comment on `keystone document `_ + * `PTLs `_ + * `APC `_ + * `ATC `_ + * Exercise: each APC / ATC in the class add a URL to the etherpad proving it + +* `"Big Tent" and tags `_ + (`slides <04-program-ecosystem.html>`__) + + * `OpenStack Project Teams `__ + * `List of approved tags `_ + * `Understanding the DefCore Guidelines `_ + * `Core Definition `_ + * `Stackforge `_ + * `How to add a project to Stackforge `_ + * Exercise: What kind of Program do you contribute to ? + +* `Design summits `_ + (`slides <05-design-summit.html>`__) + + * `Propose sessions `_ + * `List of sessions `_ + * `Liberty Summit Etherpads `_ + * Exercise: Add a session proposal regarding your contribution in an + etherpad, review two proposals + +* `IRC meetings `_ + (`slides <06-irc-meetings.html>`__) + + * `IRC Services `_ + * `meetbot `_ + * `OpenStack IRC channels `_ + * `IRC Logs `_ + * ``#info`` - Add an info item to the minutes. People should liberally use + this for important things they say, so that they can be logged in the + minutes. + * ``#action`` - Document an action item in the minutes. Include any + nicknames in the line, and the item will be assigned to them. (nicknames + are case-sensitive) + * ``#help`` - Add a "Call for Help" to the minutes. Use this command when + you need to recruit someone to do a task. (Counter-intuitively, this + doesn't provide help on the bot) + * Exercise: lunch menu online meeting + +Workflow of an OpenStack contribution and tools (3h including 2h exercises) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +* `devstack `_ + (`slides <11-devstack.html>`__) + + * Ubuntu or Fedora + * ``git clone https://github.com/openstack-dev/devstack.git`` + * `minimal configuration `_ + * ``cd devstack; ./stack.sh`` + * Exercise: get the code for the targeted contribution + +* `How_To_Contribute URL `_ + (`slides <12-howtocontribute.html>`__) + + * `Puppet `_ + * `Documentation `_ + * `Training guides `_ + * Excercise: Apply for individual membership and sign the CLA + +* `Launchpad `_ (`slides <13-launchpad.html>`__) + + * `Blueprints `_ + * `Bugs `_ + + * `Status, Importance, Assigned To, Milestone, Tags `_ + * `reporting a bug `_ + * `confirming and prioritizing `_ + * `debugging `_ + * `bugfixing `_ + + * Exercise: review other launchpad bugs and improve yours + +* How to contribute + (`slides <14-gerrit.html>`__) + + * `Developer’s Guide `_ + * `Account setup `_ + * `Git review installation `_ + * `Starting Work on a New Repository `_ + * `Development workflow `_ + * `Running unit tests `_ + * `Cross-Repository Dependencies `_ + * Exercise: push a wip or draft and invite reviewers + +* Branching model + (`slides <15-branching-model.html>`__) + + * `Branch model `_ + * `Stable branch `_ + * Exercise: checkout the latest stable branch + +* `Code Review `_ + (`slides <16-reviewing.html>`__) +* `Peer Review `_ + (`slides <17-commit-message.html>`__) + + * `Git Commit Good Practice `_ + * Gerrit Documentation: `Gerrit Code Review - A Quick Introduction `_ + * Gerrit Documentation: `Reviewing the Change `_ + * Exercise: review each other messages on the draft + +* `Jenkins (Automated testing) `_ + (`slides <18-jenkins.html>`__) + + * Exercise: add an error and match it to the jenkins message + +Second day +========== + +The Contribution Process (1 hour) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Overview of the contribution process +(`slides <19-training-contribution-process.html>`__) + +* Take the pulse of the project. +* Figure out who's behind it. +* Determine the project's social groups. +* Assess your approach. +* Engage immediately. +* Play with your network. +* Perform the smaller tasks. +* Choose a question. +* Familiarize yourself with the code of conduct. +* Understand the conventions. +* Explain what you do. +* Prepare the backport. +* Learn what's local and what's upstream. +* Learn what distinguishes good work flow from bad work flow. +* Quantify the delta. +* Speed up the acceptance. +* Determine the time frame. +* Maximize karma. +* Work in parallel. +* Archive and collect. + +Agile for Contributors (15 min) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Lego applied to Free Software contributions +(`slides <20-training-agile-for-contributors.html>`__) + +* Apply agile +* Who is the customer? +* Company & Upstream product owner +* Sprint review presentation to Upstream + +Contribution Simulation (2 hour) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The students make a virtual contribution simulation using Lego bricks as +props, with the goal of expanding a Lego town, built by upstream. They are +divided into teams; the teacher is by turns the product owner in the company +and the upstream. + +Contribution Planning (2 hours) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +`ODP slides `_ +`PDF slides `_ + +* The students use template slides to prepare a 5-minute presentation of + their planned contribution. +* A sample presentation is given by the teacher, as an example. +* Each student group prepares a presentation describing: + * the contribution they plan to work on during the online sessions, + * how they will engage with the Upstream, + * how it contributes to the company's agenda + * and whom they will be working with. +* Each student group presents its slides to the class + +Etherpad +~~~~~~~~ + +https://etherpad.openstack.org/p/upstream-training-vancouver + +`Complete index in slide format only `_ diff --git a/tox.ini b/tox.ini index 9c9d993d..135e5982 100644 --- a/tox.ini +++ b/tox.ini @@ -63,7 +63,7 @@ commands = # Build upstream-training slides sphinx-build -b slides doc/upstream-training/source/ doc/upstream-training/build/slides # Build upstream landing page index.html - sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst + sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst doc/upstream-training/upstream-details.rst # Build training-guides slides sphinx-build -b slides doc/training-guides/associate-guide/ doc/training-guides/associate-guide/build/slides # Publish as draft @@ -77,7 +77,7 @@ commands = # Build upstream-training slides sphinx-build -b slides doc/upstream-training/source/ doc/upstream-training/build/slides # Build upstream landing page index.html - sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst + sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst doc/upstream-training/upstream-details.rst # Build training-guides slides sphinx-build -b slides doc/training-guides/associate-guide/ doc/training-guides/associate-guide/build/slides # Publish as draft @@ -94,7 +94,7 @@ commands = # Build upstream-training slides sphinx-build -b slides doc/upstream-training/source/ doc/upstream-training/build/slides # Build upstream landing page index.html - sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst + sphinx-build -b html doc/upstream-training doc/upstream-training/build/slides doc/upstream-training/index.rst doc/upstream-training/upstream-details.rst [testenv:training-slides] commands =