{"id":830,"date":"2014-01-20T09:12:42","date_gmt":"2014-01-20T08:12:42","guid":{"rendered":"http:\/\/leanmagazine.net\/?p=830"},"modified":"2024-03-15T15:18:50","modified_gmt":"2024-03-15T14:18:50","slug":"coding-dojo","status":"publish","type":"post","link":"http:\/\/leanmagazine.net\/teamwork-2\/coding-dojo\/","title":{"rendered":"Coding Dojo"},"content":{"rendered":"

\"\"<\/a><\/p>\n

Is your Agile organization stuck in second gear, hampered by low velocity, messy code and technical debt? Perhaps you should start a coding dojo and work on improving your coding skills?<\/strong><\/em><\/h4>\n

Imagine a band that never rehearses, only performs concerts. Its members get more used to do what they do every day \u2014 but do they ever learn anything new? Obviously, they need to get together every now and then to practice and scrutinize the details of the music in order to progress as performing artists.<\/p>\n

The same could be said about professional programmers. How can they ever improve their skills and get rid of bad habits if they don\u2019t have a safe environment where they can experiment \u2013 experiment with their code, try out different languages and techniques, discuss with colleagues and have fun.<\/p>\n

Any group of developers can have fun and learn stuff by meeting and hacking something together, and if you\u2019re thinking of holding that kind of get-together, you could try the \u201cCoding Dojo\u201d format. Emily Bache has just written a book, \u201cThe Coding Dojo Handbook \u2013 a practical guide to creating a space where good programmers can become great programmers<\/a>\u201d. The book was finished in May and has attracted a lot of positive attention since.<\/p>\n

Hi Emily! How do you think the ideas and the practices of XP are doing in Swe<\/strong>den today?<\/strong><\/p>\n

eXtreme Programming attracted me precisely because it has very concrete advice for coders \u2013 things like writing tests, refactoring, pairing, and simple design. I worked on a project in 2000 where I think we used 9 of the 12 practices of XP, and it was the technical ones that really made sense to me and worked well. Since then the rest of the industry has also discovered Agile, but it\u2019s mainly the team collaboration techniques that are in XP and of course Scrum that have caught on widely. The parts of XP that require a coder to change the way they work are not nearly as widespread. I didn\u2019t expect that.<\/p>\n

Why are they still import<\/strong>ant, in a time when Agile and Scrum are much \u201csexier\u201d?<\/strong><\/p>\n

James Shore and Diana Larsen have come up with a model of \u2018Agile Fluency\u2019 (see martinfowler. com) based on their observations of many teams and organizations. It matches my observations too, and I think it\u2019s useful. They talk about \u201cone star agile\u201d which is basically unadorned Scrum, or the XP team collaboration practices without the technical ones. This is where they put nearly half of agile teams today. The trouble with one star agile is that although you can deliver business value, and measure progress in those terms, you can\u2019t consistently deliver at will. The ability to continue to deliver new versions iteration after iteration requires \u2018two star agile\u2019, and for that you need all the XP technical practices. You have to invest in automated tests, refactoring, simple design, and spreading knowledge around the team via pairing or similar. James & Diana report that only perhaps a third of teams are doing \u2018two star\u2019 agile.<\/p>\n

Which problems are we facing if we can\u2019t understand that there is still an import<\/strong>ant role to play for XP?<\/strong><\/p>\n

The problem with \u2018one star\u2019 agile is that you can\u2019t reliably deliver new software when the customer wants it, in the long term. In an agile world where you deliver a new version of the software every iteration, without any big \u2018design\u2019 phase, means it\u2019s easy for the design and architecture to degrade. People hack together new features, without paying attention to the big picture. After a while, the team will complain about \u2018technical debt\u2019, and the bug count will start rising. Developers find it harder and harder to introduce new features without breaking existing ones. Without good automated tests, skilled developers and a mandate to write clean code, your codebase can really get out of hand. You become unable to deliver new functionality in any reasonable timeframe.<\/p>\n

So, how can coding dojos help to improve this situation?<\/strong><\/p>\n

Coding Dojos are an opportunity for programmers to take some time out from the complexities and stress of the production<\/p>\n

system, and just work on improving their skills. If you bring all the coders from your team into the Dojo, you can not only practice writing some really good code together, but you can have valuable discussions about what your team thinks is important when it comes to things like simple design and refactoring. You can learn a complex skill like Test Driven Development, that is usually difficult to practice in your average production codebase. When you step out of the Dojo, back into your production code, hopefully you\u2019ll feel more motivated and equipped to write tests, clean your code, and collaborate together effectively.
\n

\n

Coding Dojo 1-2-3<\/h1>\n

Coding Dojo in some simple steps<\/h3>\n

\u201cThrow in a suitably puzzling Code Kata (exercise) and a safe environment to discuss topics like design, testing, refactoring, choice of code editor, tools \u2026\u00a0 and you\u2019re away! You\u2019ll hardly be able to stop them talking and writing code and learning from one another!<\/p>\n

Programmers generally love the plain activity of writing code, away from managers and deadlines and production bugs. When they\u2019ve got over their shyness, most are delighted to show others how well they can actually write code, as well as to pick up tips and advice from them.<\/p>\n

I think there are a few aspects which distinguish a Coding Dojo from are available to come to the Dojo. Perhaps more importantly, you also need a random meeting where a bunch of coders get together and hack on something, though. I think you\u2019ll learn more if you add just a little structure:<\/p>\n

    \n
  • Hold an introduction and retrospective.<\/li>\n
  • Write tests as well as code.<\/li>\n
  • Show your working.<\/li>\n
  • Have moderation or facilitation.<\/li>\n<\/ul>\n

    On a practical level, you need a suitable room with a projector, enough laptops for everyone to pair program, and a couple of hours, perhaps every week or every iteration, when coders some people who are willing to facilitate or moderate the meetings. Those people may have to do a bit of preparation before each meeting, identify a good Code Kata to work on together, read up on the coding techniques the group will be practicing and learning about. During the meeting the facilitator will probably not write much code themselves, their role is to keep the group discussion on track, ask questions, and offer feedback. You can rotate this role among group members, or find the person with the most enthusiasm and drive, and ask them to do it.<\/div><\/p>\n","protected":false},"excerpt":{"rendered":"

    Is your Agile organization stuck in second gear, hampered by low velocity, messy code and technical debt? Perhaps you should start a coding dojo and work on improving your coding skills? Imagine a band that never rehearses, only performs concerts. Its members get more used to do what they do […]<\/p>\n","protected":false},"author":32,"featured_media":837,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[67,66,83,51],"tags":[6,57,58,33],"_links":{"self":[{"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/posts\/830"}],"collection":[{"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/users\/32"}],"replies":[{"embeddable":true,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/comments?post=830"}],"version-history":[{"count":27,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/posts\/830\/revisions"}],"predecessor-version":[{"id":1125,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/posts\/830\/revisions\/1125"}],"wp:featuredmedia":[{"embeddable":true,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/media\/837"}],"wp:attachment":[{"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/media?parent=830"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/categories?post=830"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/leanmagazine.net\/wp-json\/wp\/v2\/tags?post=830"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}