How do I learn Ruby on Rails? Vim? Test-Driven Development?
Someone asks us these questions weekly. We think we finally have good answers.
Extracting answers from apprentice.io
apprentice.io is a program designed around 1-to-1 mentor-to-apprentice relationships with a heavy emphasis on pair programming.
However, each apprentice additionally has extra time each week to study topics of their choice. They set goals with their mentors and are held accountable to reaching them by publicizing the goals in an internal wiki.
Example goals include:
- Read chapters 14 and 17 of The RSpec Book.
- Review and merge a pull request on an open source project.
- Write blog post about anonymizing data.
One curriculum does not fit all
We've been calling each apprentice's wiki page their "trail map".
To us, the "trail map" metaphor relates to hikers, bikers, and skiiers:
- start in different places
- want to go to different places
- often change direction mid-journey
Likewise, apprentices (and anyone learning a topic):
- have different past experiences
- have different learning styles
- change their goals mid-process
With 12 apprentices in the apprentice.io program, we've noticed common patterns in each apprentice's trail map.
So, we've consolidated trails into a default trail map and we're pleased to now announce its release under a Creative Commons Atribution license.
You're free to use the trail map however you'd like, even commercial training.
The trails exist as a single git repository on Github named Trail Map:
We hope learners everywhere will fork these trails for their own learning purposes and submit improvements via pull requests.
Each trail has three sections:
- Critical learning
- Ongoing reference
This section lists things like books or blog posts to read, screencasts to watch, code to read or write, and koans or tutorials to complete.
In each topic, we aren't aiming for greatest depth, but rather the most efficient way for the learner to become productive.
For example: we suggest chapters, rather than entire books, to read.
This section lists simple tasks the learner should be able to perform during routine development. We've never liked quizzes or certifications, but some hueristic is useful for assessment. We think self-assessment is a simple, fast, and low-stress approach.
For example: we say you know everyday git when you can (among other things), "stage a file, create a commit, and push to a remote branch."
This section lists things like man pages and API documentation which we'll always reference regardless of experience. Many things are not worth memorizing.
For example, we suggest that a developer refers to
man git-rebase during a
This is a work in progress. We plan to add and edit trails as new resources are released or people tell us better ways they're learning a topic.
We'd love to get your feedback in the form of GitHub Issues.