<?xml version="1.0" encoding="UTF-8"?>
<!--Generated by Site Server v6.0.0 (http://www.squarespace.com) on Wed, 25 Dec 2013 00:32:04 GMT--><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:media="http://www.rssboard.org/media-rss" version="2.0"><channel><title>f3yourmind</title><link>http://f3yourmind.net/</link><lastBuildDate>Sun, 22 Dec 2013 15:39:44 +0000</lastBuildDate><language>en-ZA</language><generator>Site Server v6.0.0 (http://www.squarespace.com)</generator><description>Ubuntu coding ... for your friends</description><item><title>We are better than this</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Sun, 22 Dec 2013 15:22:53 +0000</pubDate><link>http://f3yourmind.net/blog/category/we-are-better-than-this</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:52b6ef82e4b0818dc1cfa5e6</guid><description><![CDATA[<p>The people whose contributions to a public Twitter conversation that I mentioned in my last blog post were offended by my opinion on themes that we touched upon. &nbsp;I've apologised over Twitter that my intention was not to be personal, negative nor offensive. &nbsp;I've read my blog post again, taken in the feedback over Twitter and from <a target="_blank" href="http://kevintrethewey.com/Pages/AslamConversation.html">Kevin's blog</a><span>. &nbsp;I believe that I could have given better context by acknowledging the value of the code retreat and Kevin's efforts in the community. &nbsp;Also, I could have expressed my initial tweet differently or at a different time. &nbsp;That it distracted Kevin from his code retreat was insensitive of me.</span></p><p><span>Events like Kevin's code retreats, Black Girls Code, and other initiatives are important to improving our community and software development in South Africa, in general. &nbsp;Yet, we are still facing glaring disparities in our sector and in our country that I find difficult to ignore. &nbsp;My fear is if we all take defensive positions, we may never ever discuss such matters openly and respectfully. &nbsp;Like I said in my twitter conversation to Kevin, this is not about him and not about me too. &nbsp;It is about us and our future.</span></p><p>The fight for equality is so much tougher when we have freedom.</p>]]></description></item><item><title>A question of demographics and then some</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Tue, 17 Dec 2013 11:59:13 +0000</pubDate><link>http://f3yourmind.net/blog/category/a-question-of-demographics-and-then-some</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:52ac5511e4b09df32bf1d30d</guid><description><![CDATA[
	
	
		
			
				<a target="_blank" href="https://twitter.com/aslamkhn/status/411766965691506688">
			
				
					<img data-image-id="52b02e12e4b0f7406a3c5dfd" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="452x518" alt="jhb-code-retreat.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02e12e4b0f7406a3c5dfd/1387277843432/jhb-code-retreat.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02e12e4b0f7406a3c5dfd/1387277843432/jhb-code-retreat.png" />
				
			
				</a>
			

			

		
	
	
<p><strong>Update:</strong>&nbsp;Kevin Trethewey has extended this conversation on <a target="_blank" href="http://kevintrethewey.com/Pages/AslamConversation.html">his blog</a>.</p><p>&nbsp;</p><p>I commented on a photograph that&nbsp;<a target="_blank" href="https://twitter.com/KevinTrethewey">Kevin Trethewey</a> shared of the code retreat that was hosted in Johannesburg, South Africa recently. &nbsp;His response was very defensive and it clearly showed that he was taking my observation personally. &nbsp;That was something that I didn't anticipate, as I have not seen Kevin carry prejudices of other race groups.</p><p><span>What followed was quite an interesting conversation on the disproportionate representation of non-whites in the South African software community. &nbsp;</span><span>I'm going to comment on parts of this conversation. &nbsp;For the full conversation, go&nbsp;</span><a target="_blank" href="https://twitter.com/aslamkhn/status/411766965691506688">here</a><span>. </span></p><p><span>A point to note here is how quickly people focused on racial composition as opposed to gender composition of the group. &nbsp;That is a problem in itself, even for the most gender-aware man in a software community.</span></p><p><span>This is a long, long, long post, mostly because it is a brain dump of the themes that were flowing in this conversation.</span></p><hr />
	
	
		
			
				
					<img data-image-id="52b02d88e4b01438ef9df78a" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="455x92" alt="cr-2.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02d88e4b01438ef9df78a/1387277705888/cr-2.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02d88e4b01438ef9df78a/1387277705888/cr-2.png" />
				
			

			

		
	
	
<h2><strong>There &nbsp;is adequate opportunity and access for everyone</strong></h2><p><span>Kevin believes&nbsp;that there is fair access and opportunity for all of us to attend an event such as the code retreat. &nbsp;I disagree. For example, I know a few black software developers that don't live in a conveniently accessible middle class suburb. &nbsp;For them, getting to work is a challenge. &nbsp;To get to a community event outside of the peak public transport service hours is a huge issue. &nbsp;The same applies to people attending university. &nbsp;A black kid living in a township with minimal to zero essential services loses at least 3 hours of study time a day when compared to her more privileged peers. &nbsp;Accumulate that over a month and we find that she loses about 6 days of work a month. &nbsp;Our lives are not equal in far more fundamental ways than we wish to acknowledge.</span></p><p>It is also a matter of survival, and not that people lack ambition to be better developers. &nbsp;When we have less than enough of everything that is essential for living, then a meagre salary is a big deal. &nbsp;Many black developers I know are supporting their entire family, if not an extended family. &nbsp;When we're in survival mode, ambition is lower priority.</p><p>I would love to see events hosted closer to the people that have greater logistical challenges. &nbsp;That's why Braamfontein was a good venue for Agile Africa. &nbsp;Maybe in 2014, we will have a software conference in Soweto for the first time. &nbsp;When I want to help someone out of a dark place, I prefer to go into the dark and walk out with them, taking the bumps together, than to just stand outside and shine a light in the distance to where they should go.</p><hr />
	
	
		
			
				
					<img data-image-id="52b030f8e4b015164372b94d" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="470x93" alt="cr-4.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b030f8e4b015164372b94d/1387278584413/cr-4.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b030f8e4b015164372b94d/1387278584413/cr-4.png" />
				
			

			

		
	
	
<h2><strong>People are apathetic</strong></h2><p><a href="https://twitter.com/simonstewart">Simon Stewart</a><span>&nbsp;was of the opinion that it is a lack of caring - an apathy. &nbsp;I don't know which group of people Simon refers to here so I will steer clear of making assumptions. &nbsp;What I have noticed is that the majority of software developers don't care much for self-learning. &nbsp;The code retreat that sparked this discussion is a case in point. &nbsp;Twenty seven developers pitch up to practice their TDD skills. &nbsp;I don't know how many developers there are in Johannesburg, but I guess that this is less than 1% of the total. &nbsp;Regardless, I don't have a problem with this apathy. &nbsp;Some people "give a shit" about different things, like earning a salary first. &nbsp;Because they care less for self-learning, does not mean they don't care at all. &nbsp;It just means that their value system is stacked differently from others.</span></p><p><span>I don't believe it is about software craftsmanship either. &nbsp;I think software craftsmanship as a community appeals to people that share that value system and the way that community engages with others. &nbsp;I'm not one for the craftsmanship movement for reasons that are irrelevant here. &nbsp;However, I do respect that this community has a right to exist alongside all the others. &nbsp;Not caring about software craftsmanship does not mean that a developer does not care about growing. &nbsp;Some of the most accomplished, self-taught developers I know care far less for craftsmanship than I do.</span>&nbsp;&nbsp;<span>We need to help people understand their potential, and provide diverse ways in which they can fulfil their potential. &nbsp;Sometimes people will break through that ceiling, setting up a new potential to fulfil.</span></p><hr />
	
	
		
			
				
					<img data-image-id="52b02f66e4b0324b1f665b6b" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="444x91" alt="cr-3.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02f66e4b0324b1f665b6b/1387278182641/cr-3.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02f66e4b0324b1f665b6b/1387278182641/cr-3.png" />
				
			

			

		
	
	
<h2><strong>Lack of diversity is commonplace</strong></h2><p><span>Simon rightfully points out that the lack of diversity is common. &nbsp;I concur. &nbsp;I've spoken at a few conferences outside our continent and it is the same in most places, as much as it is within ours. &nbsp;Again, that it is so does not mean that we should accept this. &nbsp;Make up your own mind, but I cannot accept that. &nbsp;I've been talking about diversity publicly for several years now. &nbsp;I've been on projects where the direct result of us not working with our diversity resulted in a tragic cost of the human spirit. &nbsp;I cannot accept that we are prepared to allow that to happen again and again and again.</span></p><p>I try to be a lot more aware, a lot more empathetic. &nbsp;I've been fighting my own unsettling biases to appreciate our diversity, to celebrate our differences and embrace our uniqueness. &nbsp;The scary part is this very process of appreciation demands that we drop all our prejudices. &nbsp;To do that requires self-reflection and clarity to face the truths of our deeply internalised, and camouflaged stereotypes. &nbsp;Be prepared to cry for ourselves. &nbsp;Be prepared to feel lighter on the other side of that.</p><hr />
	
	
		
			
				
					<img data-image-id="52b02fafe4b04b55eedc188b" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="469x95" alt="cr-5.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02fafe4b04b55eedc188b/1387278255874/cr-5.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b02fafe4b04b55eedc188b/1387278255874/cr-5.png" />
				
			

			

		
	
	
<h2><strong>Quotas and Meritocracy</strong></h2><p><a href="https://twitter.com/StevenMcD">Steven</a>&nbsp;asked what he thought was a silly question. &nbsp;But it is not silly at all -&nbsp;<em>"How should a code retreat represent the demographics of the country?"</em>&nbsp;&nbsp;For me it comes down to us building a significant software development sector in South Africa. &nbsp;The white minority cannot satisfy that agenda alone because there aren't enough of them. &nbsp;We need black software developers too. &nbsp;Parallel to this, we need fair and equal gender representation too. &nbsp;South Africa has one of the most humane constitutions in the world. &nbsp;Yet, I see many software developers adopt the non-inclusive behaviour of frat boys, country clubs and colonial style thinking of the west and north. &nbsp;That is a learned behaviour that I refuse subscribe to. &nbsp;Given our history of the inhumanity of apartheid, I find this behaviour equally abhorrent. &nbsp;Incidentally, I was part of a very diverse group of developers that were reflecting on what we don't like of the software development community, locally and globally. &nbsp;What emerged were distinct pointers to this imported, inhumane subculture: elitism, arrogance, fear, bullying, sexism, racism, monopolies, nepotism and a lot more.</p><p>Steven also dangled the option of quotas. &nbsp;South Africans are masters of quotas. &nbsp;We've tried that in almost everything from sports to business. &nbsp;It turns out that Steven is not offering quotas as an option. &nbsp;What is relevant for me is the other side of the quota argument - inclusion by merit. &nbsp;Meritocracy is a subtle form of exclusion. &nbsp;In Africa, where we have significant disparity on multiple levels. &nbsp;Meritocracy just widens the gap between those that have excelled and those that may excel but don't have opportunity to do so.</p><p>I've been guilty of exercising meritocracy to the extent of building a company based on inclusion by merit. &nbsp;Being elitist is one of the easiest ways of being exclusive, and oh so easy to cover up whilst staring in the face of everyone. &nbsp;What changed for me was a change in my attitude. &nbsp;I now carry an&nbsp;<em>attitude</em>&nbsp;where I respect the potential of each individual. &nbsp;I realised that we need people to contribute in their own little way, acknowledge that contribution and then help that person raise their own ceiling.</p><hr />
	
	
		
			
				
					<img data-image-id="52b0306be4b026ca4485c2d9" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="457x293" alt="cr-6.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b0306be4b026ca4485c2d9/1387278444114/cr-6.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b0306be4b026ca4485c2d9/1387278444114/cr-6.png" />
				
			

			

		
	
	
<h2><strong>We must challenge the bias of minorities</strong></h2><p>Here is Steven's alternative to quotas. &nbsp;I ask that we not flame him or attack his position. &nbsp;This is his position and I want us to respect that. &nbsp;If I want to change Steven's mind, then I need to offer him alternatives, not antagonise him.</p><p>I agree that tech events are open to everyone. &nbsp;I don't accept that non-whites and women - the "minorities" - don't attend because they hold prejudices against the pale males. &nbsp;I think the problem is to do with accessibility, opportunity and a necessity for survival prioritised higher than self-learning, as discussed above. &nbsp;By the way, Steven, as a white male, you are the minority.</p><p>Yet, there is a strong element of intimidation. &nbsp;This, we cannot ignore. &nbsp;I've been on the receiving side of intimidation. &nbsp;It is subtle and, strangely, more powerful in its exclusionary effect. &nbsp;It exhibits itself as quiet arrogance, and other times as open boorishness. &nbsp;Tech conferences are testosterone events where geeks flex their muscles using absurd measurements of superiority like "my big data is bigger than your big data" or "I've got more pull requests accepted on blah-blah-blah repo than you". &nbsp;All it takes is one moment of acknowledgement, a moment where there is a little light shining on us and people smile and say that we are awesome. &nbsp;It is that moment when we pack the soap box in our suitcase and take it everywhere. &nbsp;From that moment, the superior position is taken and others struggle to fit in, white or not, male or not. &nbsp;Tech events are open for those of us with soap boxes. Oh, and you must make sure your soap &nbsp;box is bigger than other soap boxes.</p><p>This is why I promised myself to always step off the podium and be accessible to everyone in the room and beyond. &nbsp;This topic of soapboxes, self appointed popes, cardinals and priests of industry, blogging, tweeting, etc deserves deeper discussion more than this already far too long blog post. &nbsp;And, yes, I know that my irony is that I'm blogging and tweeting too.</p><hr />
	
	
		
			
				
					<img data-image-id="52b03573e4b0532c166072bf" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="466x215" alt="cr-7.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b03573e4b0532c166072bf/1387279732507/cr-7.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b03573e4b0532c166072bf/1387279732507/cr-7.png" />
				
			

			

		
	
	
<h2><strong>Tell me when you're done talking</strong></h2><p>I was uncertain by what Kevin meant when he asked me to let him know when I'm done talking. &nbsp;It would have been easy for me to fire a flame attack along the lines of "WTF makes you think I'm all talk and no action?". &nbsp;That's not useful because twitter is a horrible medium that draws assumptions out of people. &nbsp;So, I just asked for clarity first. &nbsp;This is important; a behaviour that I try to instil in myself all the time - pause, listen, think and ask for clarification if I have even the slightest doubt. &nbsp;That double check saves me a lot of unnecessary flaming. &nbsp;I also found that asking for clarification in the face of cynicism does defuse the situation. Then again, rushing around with a burning flamethrower, defending every single one my opinions is a horrible way to spend my life. &nbsp;It doesn't take me forward in the least bit. &nbsp;Worse, still, is that it causes me to stagnate.</p><p>I do try my best to not draw public attention to the work that I do. &nbsp;I respect the privacy of being in a group and have learnt a long time ago that it is self-serving to tweet about such work. &nbsp;As a mentor to a few people for many years, I respect that unspoken code of confidentiality. &nbsp;Being a mentor, for me, is a two way street. &nbsp;I need to be equally open and honest as I expect of the other. &nbsp;Sometimes, that means being quite personal and deeply private. &nbsp;So, I don't crow about my work. &nbsp;But I blog and open conversations based on observations which I've extracted from my time with others.</p><p>Those that work closely with me know the extents to which I go to change the status quo. &nbsp;Then there are those that are even closer that know the extent to which it pains me when I can't change the status quo. &nbsp;At a deeply philosophical level, is it possible to give unconditionally - without even the tiniest drop of self-serving satisfaction?</p><hr />
	
	
		
			
				
					<img data-image-id="52b035a1e4b0532c166072d1" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="459x117" alt="cr-8.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b035a1e4b0532c166072d1/1387279777533/cr-8.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b035a1e4b0532c166072d1/1387279777533/cr-8.png" />
				
			

			

		
	
	
<h2><strong>Celebrate the success</strong></h2><p>Mark Pearl, on a separate conversation stream, reminded me that that progress was being made. &nbsp;That is true, there is progress being made. &nbsp;I mentioned that at Agile Africa that the demographics are changing, slowly for the better. &nbsp;I think we are moving forward and I am not so concerned about the pace either. &nbsp;There is a part of me, though, that is cautious of grand celebrations for small steps. &nbsp;That is just me. &nbsp;I prefer constant acknowledgment of progress for each tiny step. &nbsp;It keeps me humble, knowing that the big picture is still not fully painted.</p><hr />
	
	
		
			
				
					<img data-image-id="52b035bde4b0324077fb129e" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="469x227" alt="cr-9.png" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b035bde4b0324077fb129e/1387279806294/cr-9.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/52b035bde4b0324077fb129e/1387279806294/cr-9.png" />
				
			

			

		
	
	
<h2><strong>Can I plug in, please?</strong></h2><p>Hearing that I am doing something, Kevin invited me to breakfast to hear more so that he can plug in. &nbsp;I'm happy to share with most people, but this work isn't about plugging in. &nbsp;It is not a thing at all. &nbsp;It is about my individual behaviour and attitude. &nbsp;There are no recipes that I can offer to make this better. &nbsp;It requires me to find a connection with myself. &nbsp;It is about holding a heightened sense of self-awareness, of each thought, each action and each consequence. &nbsp;It demands a level of honesty with myself that is, at times, extremely hard to face. &nbsp;This is a journey that I've been trying to walk. &nbsp;It is painful to look in the mirror and see beyond the reflection. &nbsp;I am motivated by a belief that we have a primal encoding for decency and an inclusive humane culture. &nbsp;Everything else is an invention that is designed to obscure that basic encoding.</p><p>For more than 50% of the time, I get it wrong - my behavior and attitude. &nbsp;So, I cannot stop here and I must persevere with this. &nbsp;This is why demographic representation is important. &nbsp;It is a measure of our collective shedding of invented biases and a statement of us including each other without prejudice.</p><p>To Kevin and the others, thanks for opening a powerful, multi-faceted conversation. &nbsp;And if you want to plug-in to this inclusive, humane culture, then you will need to plug-in to yourself first. &nbsp;This is not something I can help others plug in to. &nbsp;I can only behave in a way that I want our software community to behave. &nbsp;I believe that others will change in step.</p>]]></description></item><item><title>The Genocide of South African Software Developers</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Mon, 14 Oct 2013 06:13:56 +0000</pubDate><link>http://f3yourmind.net/blog/category/bzhlsom95nw6zh5rdcb4o713a3pxve</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:525841a6e4b0c355ae9a8c21</guid><description><![CDATA[<p><span><strong>The South African Department of Basic Education has decided that the only Delphi and nothing else</strong> will be used to teach programming in our schools. &nbsp;Many of us became aware via Derek Keats' &nbsp;<a target="_blank" href="http://dkeats.com/index.php?module=blog&amp;action=viewsingle&amp;postid=gen21Srv8Nme0_40332_1381256759&amp;userid=7050120123">blog post</a>. On his blog, is a scanned copy of&nbsp;<a target="_blank" href="http://dkeats.com/usrfiles/users/7050120123/S9/SKMBT_22313100312200.pdf">Circular 9/2013</a> which communicates this decision. &nbsp;Even t</span><span>he&nbsp;</span><span>&nbsp;</span><span>Digital Portfolio Committee of the&nbsp;</span><span>&nbsp;</span><span>Cape Chamber of Commerce has issued a</span><span>&nbsp;</span><a href="http://www.linkedin.com/groups/Announcement-Chamber-Digital-Portfolio-Com-4651854.S.5793968773664886787?view=&amp;gid=4651854&amp;type=member&amp;item=5793968773664886787&amp;trk=NUS_DISC_Q-ttle">statement</a><span>&nbsp;</span><span>on this matter and are convening a meeting on 16 October 2013 to address this.</span></p>
	
	
		
			
				<a target="_blank" href="http://dkeats.com/usrfiles/users/7050120123/S9/SKMBT_22313100312200.pdf">
			
				
					<img data-image-id="525842e2e4b0d6c3d342c87e" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="1274x551" alt="Excerpt from Circular 9/2013. Source: dkeats.com" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/525842e2e4b0d6c3d342c87e/1381516003440/skmbt_22313100312200-1.png?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/525842e2e4b0d6c3d342c87e/1381516003440/skmbt_22313100312200-1.png" />
				
			
				</a>
			

			
			
				<p>Excerpt from Circular 9/2013. Source: dkeats.com</p>
			
			

		
	
	
<p><strong>That Delphi is old is irrelevant.</strong> &nbsp;For me, the issue is that Delphi is not current. &nbsp;Old and current is not the same. &nbsp;For example, Python is old. &nbsp;Python v1.0 was released in 1994, but it is still current. &nbsp;It is still under very active development and a popular choice for building software in today's world. &nbsp;Delphi is old and has tried desperately to keep up with the times. &nbsp;Delphi is no longer current. &nbsp;<span>Please do not bother pointing me to&nbsp;</span><span>&nbsp;</span><a href="http://www.embarcadero.com/products/delphi">Embarcadero's Delphi XE5</a><span>. &nbsp;Do your own homework on its market share and developer mind share.</span></p><p><strong>Currency makes the things that we wish to achieve today and tomorrow possible.</strong> &nbsp;Currency of software languages and tools instills wonder and amazement for the current generation and next. &nbsp;It was C that did it for me when I was starting out. &nbsp;That I could make LEDs flash sequentially when connected to a parallel printer port, left me breathless. &nbsp;Delphi excited <em>some</em> people in 1996. &nbsp;It excites nobody anymore. &nbsp;It has lost its currency decades ago. &nbsp;It no longer inspires people that imagine possibilities in the world of cloud, mobile, touch and the Internet of things. &nbsp;</p><p>Certainly, we can teach kids programming using Delphi and Pascal. &nbsp;We've taught programming with Pascal for years. &nbsp;And, yes, design is the hardest aspect of programming and we can argue that language is an implementation detail. &nbsp;This argument may stand up in the generality of teaching programming. &nbsp;But it falls flat when it comes to specifics of teaching programming in South Africa.</p><p><strong>The reality is that South Africa does not have a significant software development sector.</strong> &nbsp;As one of the BRICS we have an expectation that our software development sector should be comparable, in relative size, with our "developing" sisters. &nbsp;<span>Get real. We just don't have enough developers in South Africa to build a significant software development sector. &nbsp;What we do have is a marginal sector where the majority seats are occupied by a minority group. &nbsp;I can only foresee a significant software development sector when the majority of seats are occupied by the majority group in South Africa. &nbsp;Let me cut through the euphemisms. &nbsp;The majority group are not white. &nbsp;The minority group is predominantly white. &nbsp;But this is not a race issue, it is much deeper than that.</span></p><p><strong>We are in a software development crisis in South Africa.</strong> &nbsp;We do not have enough software developers. &nbsp;Forget talent, simply on quantity, the minority group cannot fix this situation. &nbsp;We need black software developers to fill the seats, first with numbers. &nbsp;The black talent drought is a different problem, but let's just stop the black software developer drought. &nbsp;We need the numbers first. &nbsp;T<span>he majority of our kids go through state schools will be left uninspired by Delphi, and turn to other careers.&nbsp;</span>Software development is not even close to being a common career option for all South African kids, and t<span>he Department slams the door shut.</span><span>&nbsp;</span></p><p><strong>Kids in private, independent and previously advantaged schools will be ok.</strong> &nbsp;I know this because my son attends a private, independent school. &nbsp;These kids will be inspired. &nbsp;They will feel that sense of wonder and will reach for a career in software development. &nbsp;And we will continue fooling ourselves building a software development sector with a minority group.</p><p><strong>I wonder whether the Department of Basic Education knows that it is responsible for the under-development of South Africa.</strong> &nbsp;<span>Yes, Mr. SG Padayachee, you and whoever is advising you are killing an entire generation of software developers. &nbsp;It is a genocide of software developers.</span></p>]]></description></item><item><title>Why am I poking SUGSA?</title><category>Conferences</category><category>General</category><dc:creator>Aslam Khan</dc:creator><pubDate>Tue, 27 Aug 2013 12:46:35 +0000</pubDate><link>http://f3yourmind.net/blog/category/real-transformation</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:521a12dfe4b09bd519def9cb</guid><description><![CDATA[
	
	
		
			
				
					<img data-image-id="521a58dbe4b0d4fe197acfd5" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="205x83" alt="Logo.jpg" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/521a58dbe4b0d4fe197acfd5/1377458396018/Logo.jpg?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/521a58dbe4b0d4fe197acfd5/1377458396018/Logo.jpg" />
				
			

			

		
	
	
<p>I've been taking a poke or few at SUGSA on twitter in the last few weeks around the2013 <a target="_blank" href="http://sugsa.org.za/2013-scrum-gathering/">South African Scrum Gathering</a>.&nbsp; It's time to put it into perspective.&nbsp; My proposal to present a session at the conference been accepted and I have declined this acceptance.</p><p>This is not news to the SUGSA committee.&nbsp; I have communicated my 
decision and my reasons to the SUGSA committee.&nbsp; I have also had 
one-on-one discussions with a few committee members.&nbsp; I am satisfied 
that the committee has received and digested my reasons.&nbsp; Individuals on
 the committee have assured me that my feedback is in line with their 
values and that they aim to address it in the future.&nbsp; </p><p>My poking is just me pressuring SUGSA to recognize a few issues which I believe are important to our community, and to force the committee to address us on their position.&nbsp; Tell all of us, not just me, of your position and we shall listen.&nbsp; That is all, no more, no less.<br></p><p>These are the issues that I raised with SUGSA.<br></p><ul><li>African conferences need to be representative of our community.&nbsp; One way is to nominate an African keynote.&nbsp; It will take a courageous decision but it can still happen.&nbsp;&nbsp; Agile Africa responded symbolically very late and it was fantastic.<br></li><li>We must embrace our diversity and find ways of breaking the polarised community that exists in Cape Town.&nbsp; I think the people from Cape Town that attended Agile Africa in Johannesburg were surprised by the diversity of speakers and audience at that conference.</li><li>Be transparent with the review process.&nbsp; The committee needs to maintain its independence and having committee members occupying several speaking slots sends the wrong message.&nbsp; I've seen that in other communities where the committee became the soapbox for individuals.&nbsp; If I was on the committee, I would withdraw my proposal on principal.&nbsp; I know of one committee member that did this.&nbsp; Thank you for taking a courageous step.<br></li><li>I also questioned the expertise within the committee, especially for technical submissions.&nbsp; That is my perception and there is every chance that I might be wrong.&nbsp; I welcome the correction.&nbsp;</li></ul><p>This is not a boycott.&nbsp;&nbsp; I will still attend as a paying conference attendee.&nbsp; I appreciate the 
learning I receive from this community and look forward to more of the 
same.</p><p>I believe my issues have been heard and my actions, seemingly harsh to some, was necessary.&nbsp; I still want SUGSA to take a position publicly and I leave it them to figure out when and how.&nbsp; The SUGSA committee have invited me to discuss this further and&nbsp; I look forward to that.<br></p><p>Thanks go out to Austin Fagan, Sam Laing and Karen Greaves who gave me perspective to resolve a few internal conflicts, and shape my thoughts on why I am doing this, and what I expect out of it.&nbsp; Had they not given input, this could have been unnecessarily ugly.<br></p>]]></description><media:content type="image/jpeg" url="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/521a12dfe4b09bd519def9cb/1377611241911/500w/Logo.jpg" medium="image" isDefault="true" width="205" height="83"><media:title type="plain">Why am I poking SUGSA?</media:title></media:content></item><item><title>Why Maths Matters</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Sun, 25 Aug 2013 19:11:53 +0000</pubDate><link>http://f3yourmind.net/blog/category/why-queue-theory-matters</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:511b6b10e4b0331c0eb5a89b</guid><description><![CDATA[<p>A few months ago I was working on a piece of code that polls a service for a set of data, then for each item in the set, sends a request to a second service.&nbsp; This was just one part of a pipeline of data processing.&nbsp; My first naive solution was to just take a guess at the polling interval and the buffer size of the sets and hope for the best.&nbsp; Then, I made these two parameters configurable.&nbsp; Now, someone else is responsible for the guesses.</p><p>The actual problem is that I was irresponsible.&nbsp; The situation called for precision in my design and I was being casual.&nbsp; I focused on the plumbing (i.e. HTTP requests) and not the underlying questions that needed answers.&nbsp; For example,<br></p><ul><li>How big a buffer do I need for the data set?</li><li>How frequently must I poll for new data?</li><li>How frequently can I push data out?&nbsp;</li><li>How can I reduce the push rate if the receiver cannot accept data faster than I can give it?<br></li></ul><p>One very precise model comes ready made and is known as the <a target="_blank" href="http://en.wikipedia.org/wiki/Leaky_bucket">leaky bucket</a> problem.&nbsp; The leaky bucket solution is applied very often in low level networking solutions, but is just as applicable in my problem space.&nbsp; Now before you roll your eyes and fake a yawn at the maths behind this, hear me out.</p>
	
	
		
			
				
					<img data-image-id="521a577de4b00b7f8baec518" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="500x319" alt="Transient" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/521a577de4b00b7f8baec518/1377458047360/?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/t/521a577de4b00b7f8baec518/1377458047360/" />
				
			

			

		
	
	
<p>The moment we go into higher order control systems, we need higher order maths to build precise mathematical models of these systems. That is not the maths that I'm suggesting we chase.&nbsp; Instead, with a little bit of creativity and some strategic design constraints, we may be able to reduce many classes of systems to first and second order systems. In other words, introduce constants until you have one or two variables that you can tweak.<br></p><p>This is exactly the situation that I had.&nbsp; Sure, there were more than two buffers to be managed, but I was in a position to fix the size of some buffers or the flow rates.&nbsp; Then, the buffers and flow rates that were critical to me could be modeled with straight forward linear equations.<br></p><p>Had I done this, then I would have been in a position to have built a system that could have adjusted itself to a steady state, without frequent reconfiguration.&nbsp; The fact that I was casual about my design led directly to a case of the pipeline being in a non-deterministic state.&nbsp; This problem was highlighted early when the users started asking for different kinds of "status reports" for data flowing through the pipeline.&nbsp; Of course, being casual about it, I treated it as a feature request and implemented a few reports.<br></p><p>This is when maths and science make a difference in software development.&nbsp; Unsurprisingly, mathematical models are generally deterministic, self contained (i.e. highly cohesive), and at the right level of abstraction for the problem.&nbsp; And all of those characteristics lead to highly testable models that you can do in wee little steps, test first.<br></p><p>That's why it matters to have a maths background.&nbsp; And if you came into software development through some other route, then do some layman studying of algorithms, control systems and simple higher order maths.&nbsp; It will serve you well forever. It will certainly give you a design advantage when you need it most.&nbsp; Right now, I'll take any advantage because design is just so darn difficult.<br></p>]]></description><media:content type="image/png" url="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/511b6b10e4b0331c0eb5a89b/1377458176052/500w/" medium="image" isDefault="true" width="500" height="319"><media:title type="plain">Why Maths Matters</media:title></media:content></item><item><title>Beyond Apartheid and Democracy</title><category>Conferences</category><dc:creator>Aslam Khan</dc:creator><pubDate>Wed, 14 Aug 2013 13:57:35 +0000</pubDate><link>http://f3yourmind.net/blog/category/beyond-apartheid-and-democracy</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:520b8cdee4b08d9753cc5855</guid><description><![CDATA[<p>Here's the slide deck from my talk that I did at the inaugural Agile Africa conference, Johannesburg, S.Africa, August 2013.&nbsp; Sadly, some slides are completely meaningless because they lack context and explanation.&nbsp; For those that attended, I hope it gives you a reminder of the things we spoke about.<br></p><p></p><iframe frameborder="0" height="356" marginheight="0" scrolling="no" data-embed="true" data-image-dimensions="425x355" webkitallowfullscreen="" allowfullscreen="" width="100%" marginwidth="0" src="https://www.slideshare.net/slideshow/embed_code/25241438?wmode=opaque" mozallowfullscreen=""> </iframe>  <strong> <a title="Beyond Apartheid and Democracy" target="_blank" href="https://www.slideshare.net/aslamkhn/beyond-apartheid-and-democracy">Beyond Apartheid and Democracy</a> </strong> from <strong><a target="_blank" href="http://www.slideshare.net/aslamkhn">Aslam Khan</a></strong> ]]></description></item><item><title>An African Keynote</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Tue, 02 Jul 2013 05:15:27 +0000</pubDate><link>http://f3yourmind.net/blog/category/an-african-keynote</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:51d1eec4e4b09d5758496f5f</guid><description><![CDATA[<p><span>Now that we are attracting international speakers, does it bother anyone that we have never had an African keynote in any of our conferences. &nbsp;I can understand that people want to learn from people to whom they don't normally have access. &nbsp;But why don't we have an African give the keynote?</span><br></p><p>Before I go off bleating about how this bothers me, I thought I'd understand this thing called a keynote. &nbsp;It originates from music, a capella in particular. &nbsp;At the start of a performance, someone sang the key note and others followed, calibrating to that note. &nbsp;In a similar vein, a conference keynote is meant to set the tone for the conference. &nbsp;It lays the foundation for the other speakers to build upon. &nbsp;It calibrates the conference for the speakers and attendees. &nbsp;If the keynote inspires, all the better.</p><p><strong>What should we expect of anyone that is giving a keynote?</strong>&nbsp; &nbsp;<span>The first criteria is that the person must have good insights into the subject of the conference. &nbsp;The person does not need to be an expert, but should have a good understanding the subject and the context thereof for the audience. &nbsp;Second is to have the ability to deliver a decent talk, one that shapes the conference. &nbsp;Being a great speaker is either a talent or a learned skill. Either way, a person gets better the more they speak. &nbsp;Lastly, the person must speak with passion, from the heart and create an energy that inspires, even if it only lasts for the duration of the conference.</span></p><p><strong>What, then, does it take for someone to give an African keynote? </strong>&nbsp;I think it is the most important to understand Africa, her people, her history, her challenges and her future.<span> &nbsp;Without this, an African software conference lacks context for our the challenges and constraints.</span></p><p><span>It's great to hear someone from Amazon or Facebook about their grand ultra-scalable, cloud infrastructure. &nbsp;Sure, now try that in Africa when a break in an undersea cable is the equivalent of severing your carotid artery. &nbsp;Then try that in Africa where the minimum living wage is equivalent or less to the bandwidth costs for a month for an average middle class home. &nbsp;How do you build a scalable cloud infrastructure that reaches into the tiniest village in, literally, dark Africa.</span></p><p>Forget technical challenges, let's take agile conferences where trust, collaboration and self-organising teams are common themes. &nbsp;And magic and transformation too. &nbsp;If you grew up in Africa, then you will understand that trust is not a commodity item. &nbsp;When an entire continent of people have been exploited as slaves for centuries, cultures systematically eradicated for the wealth of privileged few, establishing trust and collaboration is a different ball game. &nbsp;Try transforming a team with distinct divisions, each with deeply entrenched prejudices for each other. &nbsp;This is Africa. She is not your average, homogeneous nanny state that tells you what to think.</p><p><strong>I believe that we do have people in Africa that easily meet all these criteria</strong><span>, and we are certain to have more in coming years. &nbsp;A couple or years ago, ICSE was held in Cape Town and Archbishop Tutu gave the keynote address. &nbsp;Here is a person of Africa addressing the academic elite of the software world, and he is not even a geek. &nbsp;We don't need to have instantly recognisable names. &nbsp;From the top of my head, here are three names that you may or may not have heard that are more than qualified to keynote African software development conferences.</span><br></p><ul><li>Enyo Kumahor</li><li>Herman Chinery-Hess</li><li>Jonathan Jansen</li></ul><p></p><p><strong>Some technical topics transcend culture.</strong> &nbsp;For example, object orientated or functional programming can be learnt regardless of who we are and where we come from. &nbsp;And in a localised way, a few refactoring steps to clean out a piece of smelly code doesn't impact on our culture or being. &nbsp;That I can accept.&nbsp; &nbsp;What I cannot accept is when this reasoning is abused to deflate the situation of under-representation of our people. Let technical things be technical, but we also need Africans to be technical leaders. That is not the topic under discussion here.</p><p><strong>This is important.</strong>&nbsp;<span>Whether they like it or not, every African keynote spe</span><span>aker creates the path for many to walk. &nbsp;Even if it is not a keynote, an African that shares a room with a few people gathered around, listening and engaging with what is being shared is cutting down brush and laying a new path. &nbsp;These will become well worn pathways. &nbsp;And each traveler walking on it will see virgin brush that needs to be cut, and a new path will be laid. &nbsp;An African keynote can have this effect, if we allow it to happen.</span></p><p><strong>I have a challenge.</strong> &nbsp;Next up is Agile Africa which will happen in August 2013. &nbsp;This is the keynote lineup:</p><ul><li>Martin Fowler</li><li>Mitch Lacy</li><li>David Hussman</li><li><span>Amr Noaman</span></li><li>Ivar Jacobsen</li></ul><p>Amr, from Egypt, is the one African in the keynote lineup. &nbsp;That is fantastic. I challenge the JCSE to rather reduce the number of keynotes to just two or three and nominate other Africans to stand alongside Amr Noaman.&nbsp;</p><p>In October is the Scrum Gathering in Cape Town. &nbsp;Here's the keynote lineup.</p><ul><li>Geoff Watts</li><li>Dave Snowden</li><li>Alexander Kjerulf</li></ul><p>I challenge the SUGSA committee to offer these speakers a regular slot and give our African community African keynotes. &nbsp;<span>I am not asking for the current of the keynotes to be rejected. &nbsp;I want these experts at our conferences. &nbsp;I want to attend their sessions and learn. &nbsp;I also want us to realign them to an African context, that broadens their perspective. &nbsp;We share, we learn, we teach, we grow - it's all the same.</span></p><p><span>But &nbsp;I cannot accept that there are no African keynote speakers to be found.</span></p><p></p><p></p><p></p><p></p>]]></description></item><item><title>Get up, Stand up.</title><category>Software Development</category><category>General</category><dc:creator>Aslam Khan</dc:creator><pubDate>Wed, 19 Jun 2013 19:53:42 +0000</pubDate><link>http://f3yourmind.net/blog/category/where-are-our-people-now</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:51c15428e4b0c2b46f4b1fb8</guid><description><![CDATA[<p>I first got paid to write code in 1992. &nbsp;The few years before were the heavy days of mass protest against apartheid. &nbsp;Having a common enemy was not what drove people to change.&nbsp; It was having a common belief that we are all equal and deserve to be treated equally. It is that simple.</p><p>In the years that followed, my career always surfaced a blatant fact. &nbsp;I was always the minority in a white, male dominated industry. &nbsp;In my first job I was hired by people that also despised apartheid. &nbsp;For that I am grateful because it gave me a chance to learn without fighting for place. &nbsp;<span>But the places in which I plied my trade were dominated by white, male developers and managers with an attitude of superiority by entitlement, birth, law and any other decree.</span></p><p>And today I am still the minority in a white, male dominated industry. &nbsp;I don't need hard stats and precise surveys when it is patently obvious from the demographics at community events, conferences, start-ups and cubicle farms that black software development has not gained a foothold in our industry. &nbsp;It is especially so in Cape Town, and only marginally better in Johannesburg. &nbsp;I can't speak for Durban because I haven't worked there since 2005 but it was not any better then. &nbsp;<span>It is not just South Africa. &nbsp;It is the same in Europe and North America.</span></p><p class="text-align-left">&nbsp;<span>There are at least two sides to any story. Here, the one side is with corporate South African software development as a conduit for opportunity or suppression thereof, and the other side lies with the black software developer with messed up priorities. &nbsp;</span><span>By the way, when I say "black" I mean "not white", and I everything I say is a generalization because I believe it is in the majority.</span></p><p class="text-align-left"></p><p class="text-align-left"><strong>In my experience corporate South African software development perpetuates apartheid.</strong> &nbsp;There are official policies and frameworks for employment of people and for furthering their careers. &nbsp;There is nothing wrong with these frameworks. But like all rules, how we use them matters.</p><p class="text-align-left">A few weeks ago I had another black developer share his entrance into a prominent consulting company. &nbsp;He was offered an internship whilst a white male of equal qualification was offered a full contract. &nbsp;When his internship was over, he was not offered a contract on the grounds that his line manager did not like his "work ethic". &nbsp;Really? Who's work ethic needs to be questioned? &nbsp;Today, this developer is employed as an equal in more progressive organisation with a highly respected brand that is determined to breakdown apartheid in South African software.</p><p class="text-align-left">I am yet to meet a black software developer that is leading a team, making the call on design decisions. &nbsp;Along the way, I have met many blacks in leadership positions. Many are tokens and lack the leadership and technical skill to justify their position.&nbsp; &nbsp;This is also the fault of these individuals, exploiting the rules for self gain.</p><p class="text-align-left">The majority of black software developers are either doing "maintenance" or being instructed on how to write to specification or requirement with a full blown design being given to them. &nbsp;I have met many black developers who I've seen argue their design ideas only to be later classified as not being "team players". &nbsp;This also occurs in the sugar-sweet agile "we-love-transformation-i-love-my-job" work places.</p><p><strong>What gives credence to the "inferior" black South African software developer is that black software developers are apathetic.</strong>&nbsp; &nbsp;I find it difficult to identify with someone who voluntarily accepts being treated as a second class citizen. &nbsp;I can understand the risks of 20 or more years ago, but life today is different. &nbsp;We have a voice and we have a deliberate choice of the battles that we can fight. &nbsp;This is mental slavery all over again. &nbsp;And to some extent this mental slavery is self imposed.</p><p>I can appreciate that someone with a history of poverty that is offered a monthly salary that their parents could only ever earn over several years, is driven by a more basic need and deep empathy. &nbsp;It goes horribly wrong when that is all there is to it. &nbsp;You earn your dough, but you don't earn your stripes. &nbsp;I know several black developers that have doubled or tripled salaries in a few hops inside of two years. &nbsp;These developers do nothing but give credence to the ingrained belief that black developers are not skilled.</p><p>I am fully aware of black developers working from a weaker maths and science base. &nbsp;But I am also aware that there are white software developers that also don't have a strong maths and science base. &nbsp;I have wondered about this difference: two people with equally weak programming prerequisites yet the black developer struggles and the white developer excels. &nbsp;I don't think spoken language is a significant variable here. &nbsp;The one thing that I have observed is that the white developer receives more opportunity and attention than the black developer by his white leadership. &nbsp;The black developer in turn believes that they are inferior, and the lack of opportunity and attention furthers erodes self-belief. &nbsp;Self-doubt is by the far the greatest obstacle to learning.</p><p>If you have read this far, there are several among you that have already formulated counter arguments, specific cases that justify your position too. &nbsp;I am open to hear your side. &nbsp;The problem with this blog post is that everything until now is just background to create context to put forward my belief.</p><p><strong>I believe</strong> that there is a wealth of talented software developers in Africa that understands our history and our future. I believe that as a Pan African software community we are capable of designing frugal solutions for our people and for the world.</p><p><strong>To achieve this</strong>, we must break free of our own mental slavery. &nbsp;We need to build our own solid foundation that is unshakable at our core. &nbsp;We must equip ourselves as masters of our craft. &nbsp;We must let our voices be heard in Africa and the rest of the world as voices that speak substance. &nbsp;And we must return to be with our people as no more than just people. &nbsp;<span>Our first step is to rid ourselves of apartheid in software development. &nbsp;Like Marcus Garvey said and Bob Marley sang "none but ourselves can free our mind".</span></p><p><strong>I dream </strong>that the next thought leaders of software development will be African.</p><p></p><p></p><p></p><p>&nbsp;</p>]]></description></item><item><title>Reflections of BDD Stories</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Thu, 07 Mar 2013 06:59:38 +0000</pubDate><link>http://f3yourmind.net/blog/category/reflections-of-bdd-stories</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:51383ae5e4b079b8225cbefc</guid><description><![CDATA[<p>There was an interesting discussion on the AgileSA Linked-in group around the use of BDD stories, and whether they should contain technical references or not.&nbsp; I found myself saying that I don't mind having, for example, a login story. To help <a target="_blank" href="http://drivensoftware.com/">Kevin Trethewey</a> get over the shock and horror of this, I reflected on how my use of BDD stories has changed over time.</p><p>I remember Dan North explaining BDD stories to me when it was just a thought in his own mind.&nbsp; That was around 2005 or 2006 and I remember being so inspired by the simplicity of the BDD grammar. So, seven or eight years later, let me share how my use has changed.&nbsp; And, <a href="https://twitter.com/KevinTrethewey">Kevin</a>, I hope you enjoy your own journey too. It's a lot of fun.<br></p><strong>On CRUD.</strong>&nbsp; I agree that CRUD is bad, blah, blah, blah.&nbsp; But there are times when CRUD can a valid, and reasonable design choice. I don't discount it, but it is not my first choice, and it is very rare for me. Oh, I sometimes just use it because I don't know anything else about the domain. Once I discover more, I noticed that those CRUD things, quite naturally, fade away.<br><p><strong>Who is the best judge of a story?</strong><strong></strong>&nbsp; The customer is unlikely the best person to articulate these stories, nor judge the quality of the story. I have to guide them and extract that. I now ask the following questions.</p><ul><li>Who are they? </li><li>What do they need?</li><li>What do they think they need?</li><li>What do they really want?</li></ul><p><strong>What does the story describe?</strong> Of the above questions, the last is the most powerful for me.&nbsp; It balances my perspective. It stimulates creativity and moves me from the problem space to solution space. The story then exists in the solution space; i.e. it is now reflects a design intention, not a requirement statement in the problem space.</p><p><strong></strong><strong>BDD stories are great conversation artifacts.</strong> It's like a book on a coffee table. It stimulates conversation.&nbsp; It is of same value as using a metaphor. In conversation with the customer, the story is mostly about things in the problem space. In other words, it is an analysis and clarifying tool. I found that direct, literal and very early use of this analysis statement as an executable specification results can result in brittle tests.<br></p><p><strong>On the use of technical references.</strong> When I'm working in the design space and writing design stories, then I don't mind if there is reference to a technical implementation such as a login screen.&nbsp; At some time, I have to get concrete. I like getting concrete very early and abstract from that. It's just how my mind works. So, if there is alternative authentication mechanism (say, LDAP or ActiveDirectory), then it is just another concrete implementation. If the authentication choice is an exclusive one, then, the abstraction of proprietary authentication and ActiveDirectory authentication doesn't offer any benefit. So, I'll just go for one of those and the story on task board will make reference to the technical aspects directly. It's a great reminder of a design choice that is explicit to everyone.<br></p><p><strong>Most stories start out as bad stories.</strong> My early stories in an unfamiliar domain are awful.&nbsp; Like code, the story should exhibit single responsibility. That takes a lot of domain insight and discipline. Unfortunately, refactoring stories towards single responsibility is not trivial. It's not as simple as extract class/method/variable. The result is that my story based test suite is in constant turmoil longer than it is calm with a few small ripples. For this reason, I use the story grammar as a conversation piece, but not as code artifact.<br></p><p><strong>BDD Stories on the backlog.</strong> To avoid confusion about when the story is in the problem space or solution space, I don't use BDD stories on the backlog. I prefer the XP style of a short phrase as a reminder of something to discuss.</p><p><strong>On the use of outside-in style testing.</strong> I like outside-in to analyse the problem space, but I often find it equally valuable to evolve the design from the assertions inside-out.&nbsp; I oscillate between the two perspectives rapidly and quite often. I think I'm searching for that harmony in perspective.&nbsp; I then make it a <em>choice</em> to use the BDD story as an executable test for the outside in perspective. Often, though I find it unnecessary because I already have tests that reflect that perspective; it's just not using the BDD grammar. Yet, the BDD grammar was a starting point. I just am not fixated on the BDD grammar being the ending point.<br></p><p><strong>On the BDD grammar.</strong> From a language perspective, the BDD template is a general grammar that can be used to express any domain.&nbsp; Just like we can use a general purpose language to solve any problem,&nbsp; the BDD grammar can be used similarly. Yet, we have learned that domain specific languages can be more expressive of a particular domain.&nbsp; Equivalently, I keep my mind wide open, looking for a story grammar that is domain specific.&nbsp; For example, in a time sensitive domain such as investment portfolios, I might extract a grammar that expresses time as a first class citizen. There won't be a "When" clause. I might have something like "At time t(0), the portfolio capital amount is..., at t(n) the portfolio has ..., at t(n+1) the surrender value should be ...".</p><p>Remember, these are just reflections and observations about <em>myself</em>. Please don't treat it as a gospel. You have your own journey that takes different pathways. Just enjoy those excursions.<strong></strong></p>]]></description></item><item><title>Are we there yet?</title><category>Conferences</category><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Thu, 28 Feb 2013 09:15:45 +0000</pubDate><link>http://f3yourmind.net/blog/category/are-we-there-yet</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:512d8c7ae4b0a2cb5bfdf4eb</guid><description><![CDATA[<p>This is an interactive slide deck of my talk at Agile India 2013. &nbsp;I explore the interplay and gap between the architect 
and the manager. Along the way, I point out some agile landmarks 
that we need to stop and reconsider. I will also highlight some tweaks 
that I make to find balance, finding a thread to narrow this divide.</p><p></p><iframe height="400" data-embed="true" width="550" src="http://prezi.com/embed/bh-jvo3nxs5n/?bgcolor=ffffff&amp;lock_to_path=0&amp;autoplay=no&amp;autohide_ctrls=0&amp;features=undefined&amp;disabled_features=undefined&amp;wmode=opaque" frameBorder="0"></iframe>]]></description></item><item><title>Split stories as a design activity</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Mon, 14 Jan 2013 20:46:06 +0000</pubDate><link>http://f3yourmind.net/blog/category/splitting-stories-is-a-design-activity</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50f45802e4b0838e9c61a1fd</guid><description><![CDATA[<p><em>"A story should be big enough to fit into a sprint, otherwise chop it up until it does"</em> -- this is advice that is more or less given to Scrum teams during planning or backlog grooming. The problem is that this is not easy to do.&nbsp; My friends at <a target="_blank" href="http://growingagile.co.za">Growing Agile</a> describe a few ways to achieve this (see their blog post <a target="_blank" href="http://growingagile.co.za/2012/12/breaking-down-user-stories/">Breaking Down User Stories</a>). These techniques are not wrong in any particular way, and they will certainly result in smaller stories.&nbsp; However, these are what I call "mechanized" techniques. When I've been mechanical about splitting stories, I've always ended up with weak fracture points in the <strong>problem space</strong>.&nbsp; So, I prefer to look in the <strong>solution space</strong> for boundaries that promote or retain conceptual integrity of the software. </p><p>Below are just three techniques that are quite commonly used by Scrum teams.&nbsp; I steer away from them at all costs.<br></p><ul><li><strong>CRUD</strong><strong>.</strong>&nbsp;
 I find that thinking in terms of these database operations removes a 
lot of the richness in the domain.&nbsp; Instead, I think about the life 
cycle of things.&nbsp; For example, there is no CRUD for an invoice.&nbsp; Instead
 a customer <strong>buys</strong> something which means that a sales person <strong>issues</strong> an invoice. The customer <strong>pays</strong> the invoice. Perhaps, a debtors clerk requests <strong>payment</strong> for an <strong>overdue</strong>
 invoice.&nbsp; These are all different things that can be done with an 
invoice at different times in its life.&nbsp; Note also that "creation" is
 a very special case in any life cycle, and to bring something into 
existence that maintains integrity is quite an effort.</li></ul><p></p><ul><li><strong>Dependent Stories</strong><strong>.</strong>&nbsp; I try to break all dependencies between stories.&nbsp; I've found that looking to create "stand-alone" stories results in some very deep and powerful analysis of the domain.&nbsp; Inadvertently, you will crack open a crucial part of the domain.&nbsp; Often the concept which holds several stories together in sequence turns out to be orthogonal to the original stories.&nbsp; For example, there is a workflow for invoices (issue, authorise, pay, remind, resend, etc) that can result in several dependent stories.&nbsp; Alternatively, we can model the invoice state (and operations allowed for each state) independent of the sequence(s) of states.&nbsp; Now we can build software that deals with specific sequences, independently of the operations for each state.&nbsp; This separation can lead to such powerful discussions with the domain expert.<br></li></ul><p></p><ul><li><strong>Job Functions</strong><strong>:</strong> I've 
never found job functions to yield useful modules.&nbsp; Extending the 
invoice example above, a job function breakdown could be on sales 
(create, authorise), debtors (record payment, payment reminders), 
customer service (credit notes), marketing (cross sales campaigns).&nbsp; Now
 each of those job functions work with invoices in some way, but the 
conceptual integrity and cohesion is stronger around the invoice and its
 states.&nbsp; Designing good modules is by far, the hardest part of any software design 
effort.&nbsp; Get it wrong and it will hurt.&nbsp; More often than not, it is just too costly to try to create new
 cohesive modules from code that is already laid down along job 
functions (or any other weak boundary criteria).</li></ul><p></p><p>There are significant consequences to splitting stories in the solution space. </p><ul><li>The product owner just needs a simple phrase or sentence that describes the problem space, but remains part of the feedback loop for the solution space stories.<br></li><li>Backlog grooming becomes an exercise in understanding the problem space.&nbsp; </li><li>Sprint planning blitzes (one day or less) is not sufficient.<br></li><li>To be effective, sprint planning becomes continuous; i.e. design is continuous<br></li><li>Each story can (potentially) be released on completion</li><li>Sprint boundaries (time boxes) become less important moments in time</li><li>... and you will tend towards continuous flow.<br></li></ul>]]></description></item><item><title>Live with it for a while</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Mon, 07 Jan 2013 19:50:42 +0000</pubDate><link>http://f3yourmind.net/blog/category/live-with-it</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50e97621e4b0e6a1b5e24cf1</guid><description>
</description><content:encoded><![CDATA[<p>Before I rush off and refactor my code, I like to live with my code for a while. The refactoring I do in the TDD cycle is to get rid of trivial duplication and, perhaps, some better naming. I deliberately delay extracting methods and classes and pushing up or down. For me, those are quite important design choices, and I want to make those decisions only when I have a good understanding of my problem.</p><p><strong>What do I mean by "live with it for a while"?</strong>&nbsp; Literally, I leave it alone and move along to something that is in it's vicinity.&nbsp; I choose something that is close enough that will need to interact or modify the "living-with" code.&nbsp; This new use case, scenario or question is to further my understanding of the problem and&nbsp; I choose it deliberately. If it turns out to be tangential, I don't sweat it. I just pick something else that will move me closer.&nbsp; The fact that my first choice was poor is always valuable insight into my lack of understanding of the problem.</p><blockquote><strong>Aside:</strong> The 
simplicity of my solution is directly related to my depth of 
understanding.&nbsp; The deeper I understand the problem, the simpler I can 
potentially get.&nbsp; Shallow understanding leads to more complex solutions. This takes time, and "living with it" gives me freedom to play with the problem from several angles.</blockquote><p><strong>I don't mean "ignore it after a while".</strong>&nbsp; Ignoring it is like noticing a crack on your lounge wall and after 2 weeks of doing nothing about it, you don't see it anymore. So, living with my code is <em>not</em> giving myself permission to be sloppy.&nbsp; It's deliberate choice to look for a better, simpler solution as I increase my knowledge. Once I have a bit more knowledge, I can start making more adventurous design decisions.&nbsp; I think it's almost impossible to find a simple solution if you don't have deep domain knowledge.</p><p><strong></strong><strong>It means that I refactor a little at a time frequently.</strong>&nbsp; Even if I know my code is not clean, I'd rather have a pulse for my code, and let it beat weakly.&nbsp; All I'm doing is constantly looking for little things that will make that pulse beat a bit stronger.&nbsp; I now realize that I refactor a little at a time, but almost continuously. I'm not searching for clean code. I'm searching for markers in the domain that confirm or refute my understanding.&nbsp; The clean code will come with time.<br></p><p></p><p>Living with my design for a while has saved me lots of time, especially when I'm not confident of my knowledge of the problem.&nbsp; Give it a try and let me know whether it works for you too.<br></p>]]></content:encoded></item><item><title>Cape Town's latest agile development course</title><category>Software Development</category><dc:creator>Aslam Khan</dc:creator><pubDate>Tue, 06 Nov 2012 06:25:29 +0000</pubDate><link>http://f3yourmind.net/blog/category/935arsbf368d30daitze0uubcbx05o</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:5098ad53e4b07a4c81afe425</guid><description><![CDATA[<p>I got my first break as a software developer about 20 or so years ago. &nbsp;It was the first time I heard that a table can have keys. That start put me on a career path that I never anticipated, but is thoroughly enjoyable. &nbsp;And now, finally, I've finally got a chance to give back in a way that shows my appreciation for what was offered me all those years ago. &nbsp;For those of you who know my history (or just peeked at my <a target="_blank" href="http://www.linkedin.com/in/aslamkhn">LinkedIn</a> profile), you know that I'm talking about <a target="_blank" href="http://www.krs.co.za">KRS</a>.</p><p>So, I'm quite thrilled to be a contributor and collaborator for their <a href="http://www.krs.co.za/careers/quality-training.php">Advanced Agile Developer course</a>. &nbsp;The inauguration course happens on 19 November. That's not much time, so <a target="_blank" href="http://krsagiledev.wufoo.com/forms/advanced-agile-developer-course/">book a spot</a> quickly. &nbsp;I don't want to give too much away, but I can tell you that it's going to be fun, intense, and inspiring - and seriously code centric. &nbsp;There will be times when you will feel like you just don't know how to code anymore, and then feel like you can conquer the world.</p><p>I think this is a course with a difference. &nbsp;We want to bring together developers that are already competent at writing code and want to become proficient at being agile developers. &nbsp;We made a big decision to go deep, and not skim the surface of lots of topics. &nbsp;The result is a course that is very code centric, working at quite an intensity that passionate developers will find inspiring.</p><p><span>Working with Lorraine Steyn and team KRS has the same warmth, openness, and security from 20 years ago. This is something that I know they will bring to this course in a way that I can only hope to, someday, emulate.</span></p>]]></description></item><item><title>Accurate estimation, really?</title><category>Software Development</category><dc:creator>Aslam</dc:creator><pubDate>Wed, 06 Jun 2012 08:18:35 +0000</pubDate><link>http://f3yourmind.net/blog/software-development/accurate-estimation-really</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081493e4b03ccef5787564</guid><description><![CDATA[<p>I ended up in a twitter conversation last weekend about estimation and velocity. &nbsp;It started when <a href="https://twitter.com/#!/annua">Annu Augustine</a> asked about what qualities to look for in a lead developer, other than technical skills. &nbsp;One of the qualities I put forward was accurate estimations. This went around a bit and ended up, not surprisingly for me, at velocity. &nbsp;There are a couple of points that I need to offer my opinion on:
<strong><a href="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871af/?format=original"></a></strong></p>
	
	
		
			
				
					<img data-image-id="50081448e4b03ccef57871af" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="831x234" alt="Accuracy of Estimation" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871af/1338973557000/?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871af/1338973557000/" />
				
			

			

		
	
	
<p>I ended up in a twitter conversation last weekend about estimation and velocity. &nbsp;It started when <a href="https://twitter.com/#!/annua">Annu Augustine</a> asked about what qualities to look for in a lead developer, other than technical skills. &nbsp;One of the qualities I put forward was accurate estimations. This went around a bit and ended up, not surprisingly for me, at velocity. &nbsp;There are a couple of points that I need to offer my opinion on:
</p><p><strong><a href="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871af/?format=original"></a>Accurate estimation is not an oxymoron.</strong>&nbsp; Let's just get over some technicalities first: "accurate" is not the same as "exact". &nbsp;Estimation in software is never exact, but the magnitude of accuracy is very significant. &nbsp;If I say that something will take approximately 2 weeks to achieve, then I need to qualify "approximately". &nbsp;What is the magnitude hidden behind "approximately"? &nbsp;Is it 10% accurate, 50% accurate, 80% accurate? &nbsp;Let's say it is 50% accurate. &nbsp;This means that I can finish this work at best in 1 week or worst 3 weeks. &nbsp;That's a big swing. &nbsp;As a good developer, it has to be better than 50%. &nbsp;If it's 50% or less, then it is an indicator that you are lacking understanding (i.e. knowledge) in a key part of the problem and/or solution domain. &nbsp;Then you have to estimate on what it will take to overcome that ignorance, before committing to the original request.</p>
	
	
		
			
				
					<img data-image-id="50081448e4b03ccef57871b2" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="831x234" alt="Commitment on an estimation" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871b2/1338973672000/?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871b2/1338973672000/" />
				
			

			

		
	
	
<p><strong>An estimate is not a commitment.</strong>&nbsp; If you mix these two concepts together, then you most likely will be in trouble sooner than later. &nbsp;The estimate is based on something that you understand and that you can&nbsp;foresee&nbsp;with good accuracy. &nbsp;In other words, an estimate is a prediction of the future. &nbsp;The commitment is a promise that you make on part of the estimate in order to make that prediction come true. &nbsp;If I predict that a problem can be solved in 3 days, then I may make a promise for some part of it by the end of the first day. This distinction may surprise some who have been using the poker game, or other estimation technique in Scrum. Scrum teams use estimates in planning make commitments for the entire sprint, then track and calibrate velocity via burndowns, which leads me to the next point.</p>
	
	
		
			
				
					<img data-image-id="50081448e4b03ccef57871b5" data-image-focal-point="0.5,0.5" data-type="image" data-image-dimensions="757x522" alt="velocity" data-load="false" class="thumb-image" src="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871b5/1338976374000/?format=500w" data-image="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871b5/1338976374000/" />
				
			

			

		
	
	
<p><strong><a href="http://static.squarespace.com/static/5006a671e4b09ef2252cfad4/50081442e4b03ccef57870b3/50081448e4b03ccef57871b5/?format=original"></a>Team velocity or relative estimation does not make for better estimation.</strong>&nbsp; Knowing what a team's velocity is based on tracking historical trends is only a measure of the energy the team has expended to date. &nbsp;This <em>expended</em> energy (the area under the curve) is used to predict the <em>potential</em> energy of a team. &nbsp;That's all, nothing more nor less. &nbsp;I will stick my neck out and go so far as to say that relative estimation in points is not at all about estimating, but a way to accurately predict the potential energy of a team. &nbsp;I'll go even further: relative sizing does not work because software development is about crunching <em>new</em>&nbsp;knowledge, and every new piece of work should be crunching more knowledge. &nbsp;If it's the same thing over again, then the design is flawed or at least at the wrong level of abstraction. &nbsp;Jumping levels of abstraction, and re-shaping designs takes quite a lot of knowledge crunching and is not relative to anything else but your existing knowledge. &nbsp;So, relative estimation does not make for better estimations and velocity just tells you the potential energy of the team.</p><p>Where does this leave me? &nbsp;I've given up on relative sizing and estimation. &nbsp;Knowing my own velocity has not added any value to my ability to estimate because every problem is unique in some way. &nbsp;I estimate based on the knowledge that I have at that point in time, and force myself to be aware of my accuracy. &nbsp;All of this, and more, has made me appreciate the value of one piece flow a lot more than time boxed flow.</p>]]></description></item><item><title>SDTimes, Oredev2011, Rubyfuza2012, AgileIndia2012</title><category>Conferences</category><dc:creator>Aslam</dc:creator><pubDate>Mon, 24 Oct 2011 09:07:12 +0000</pubDate><link>http://f3yourmind.net/blog/events/sdtimes-oredev2011-rubyfuza2012-agileindia2012</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081492e4b03ccef578755b</guid><description><![CDATA[<p>Over the next few months or so, I will be quite active in the conference space.  Here's what's coming up soon ...
<ul>
<li><strong>SD Times' Leaders of Agile Webinar</strong>: This is the fourth or fifth in this series hosted by Kent Beck.  It's always very engaging for me, and Kent normally asks far too many difficult questions without warning me in advance.  It's also the third time that I will be working with Henrik Kniberg.  This time we will be talking about Kanban, and should be another really fun 3 hours.  What I enjoy the most is the balance between practical experience, challenging the norm, and always the realisation that I know far too little.  It's free and you can register at <a href="http://www.sdtimes.com/content/resources.aspx?ShowOnlyResourceID=527">SD Times</a>.</li>
<li><strong>Oredev 2011</strong>:  I've been invited back to Oredev in Malmo, Sweden.  This is always a fun conference and I get some face time with my factor10 colleagues in Sweden again.  On this occassion, I will be giving two talks.  In the first I will explore the messes we make over and over again, yet we are missing some old teachings and learnings consistently.  The second is on the Java track and I will share my experiences on experimenting with Scala and Clojure, more from design and mental mindshifts, instead of the usual language and syntax changes.  Check it out at <a href="http://oredev.org/2011/speakers/aslam-khan">Oredev 2011</a>.</li>
<li><strong>rubyfuza 2012</strong>: This is the second edition of the only South African Ruby conference that I know of.  The 2011 edition was well put together with great local and overseas speakers.  Although the program is not finalised, I will be talking about using JavaScript and CoffeeScript to build parsers and grammars.  This is something that I've spent a lot of time on recently and it's changed a lot of my thinking on domain driven design implementation options.  Check out the details at <a href="http://rubyfuza.org/speakers/4">rubyfuza</a>.</li>
<li><strong>AgileIndia2012</strong>:  This is my first trip to India, and one that I am absolutely excited about.  I will be running two sessions.  One on product ownership which is a slight improvement on the sessions held for SD Times and the S.African Scrum Safari.  The other is a culmination of years of introspection on cultural differences that I face.  I explored this quite emotionally at Oredev last year and will run a more in-depth session for AgileIndia.  Check out the abstracts for my sessions <em><a href="http://submit2012india.agilealliance.org/node/8855">Practical Product Ownership: balancing strategy and development </a></em>and <em><a href="http://submit2012india.agilealliance.org/node/8858">Collaboration lessons from the Rainbow Nation</a></em> the <a href="http://agileindia2012.agilealliance.org/program/selected-proposals-from-early-bird-submission/">early bird program</a>.</li>
</ul>
<p><strong>
</strong></p>
]]></description></item><item><title>Bigger stories with few people spanning two sprints</title><category>Software Development</category><dc:creator>Aslam</dc:creator><pubDate>Sat, 17 Sep 2011 16:52:13 +0000</pubDate><link>http://f3yourmind.net/blog/software-development/bigger-stories-with-few-people-spanning-two-sprints</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081492e4b03ccef5787556</guid><description><![CDATA[<p>I came across this <a href="http://twitter.com/#!/karen_greaves/status/114669511591985152">tweet</a> by <a href="http://scrumcoaching.wordpress.com">Karen Greeves</a>.
<blockquote>Scrum Master fail... Improvement action: Bigger stories where only few members can participate should be scheduled to run over 2 sprints.</p></blockquote>
<p>After a quick twitter conversation, Karen <a href="http://twitter.com/#!/karen_greaves/status/114723282703486978">explained</a>.</p>
<blockquote><p>It removes the ability to measure progress via working software at the end of the sprint</p></blockquote>
<p>My <a href="http://twitter.com/#!/aslamkhn/status/114783356499132416">response</a> was</p>
<blockquote><p>Working software is not the only way to measure progress in a sprint. And what if it works? I think it can.</p></blockquote>
<p>It may well not be the ScrumMaster that failed when it was decided to have a bulkier story span two sprints.  I appreciate that it is a whole lot better when a story is in one sprint, and that should be our default objective.  However, it's often not so trivial.  Given that I don't have a lot of context, I will be assuming a lot.</p>
<p>In this case, it is more likely a failure of the team that they (a) accept a story to <em>develop</em> over 2 sprints, or (b) was unable to do enough analysis to consider what can be done in one sprint.  It can also be a failure on the product owner for not entering into a meaningful conversation on the details of the story, and then, again, a team failure on not engaging the PO significantly to take the problem forward.</p>
<p>If I encounter a story that spans two sprints, and that is more often than you think (often discovered mid-sprint), then I'm not interested in working software but seek clarity of understanding in that sprint.  The outcome at the end of the immediate sprint is an unambiguous story (or maybe several stories) which is a statement of the problem domain, or even better, the solution domain.  That is what I mean by working software is not the only measure of progress in a story.  It is more important to "measure" increased understanding in each sprint, and good statements in the solution domain is at the heart of knowledge crunching.</p>
<p>The most neglected aspect of working software is a measure of understanding of the solution domain.  In my experience, many teams are great at expressing the problem domain in software and their code reflects the analysis of the problem.  Consequently, the code does not reflect the understanding of the solution.  The end result is a weak design.  Over many sprints that require work in the vicinity of the weak design, there will be a degradation in velocity because the code is just baking in the problem statement, and not a well crafted solution to the problem.</p>
<p>Next, let me deal with the case of just a few team members participate and not the entire team.  I think that is completely feasible approach.  I've done it many times to great effect and with great efficiency because the conversation is a lot more direct and contained.  It is later that the distilled knowledge is shared with the team.  This is largely crunching in the problem domain with some rough models in the solution domain.  When I've included the entire team in the analysis, then the effect is one of dilution and inefficiency - too many people over a longer period.</p>
<p>Lastly, I asked "What if it works?".  While this may seem to be brash or provocative  question, it is meant literally.  <em>What if it really does work?</em> Hey, then what we've achieved as an odd case of delivery over two sprints instead of one.  If it happens often enough, then we need to adapt accordingly: increase sprint duration, have people dedicated to analysis (oops, bite me 'cos I'm creating a silo) and maybe more if we just think a bit about it.</p>
<p>So, in my opinion, it is absolutely OK to attempt the proposed solution because it is an admittance of ignorance, but if the team does not understand the actual situation they're in, then it is the failure of the team not the ScrumMaster.  I also think that we should understand the rules of the game a lot more deeply.  Like I've said in the past:</p>
<blockquote><p>It's not the rules that matter, it's what we do with the rules that counts.</p></blockquote>
<p>To each their own, and life goes on.</p>
]]></description></item><item><title>Stay in bed or come to SGZA</title><category>Conferences</category><dc:creator>Aslam</dc:creator><pubDate>Wed, 07 Sep 2011 23:41:55 +0000</pubDate><link>http://f3yourmind.net/blog/events/stay-in-bed-or-come-to-sgza</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081491e4b03ccef578754d</guid><description><![CDATA[<p>I will be hosting a 3 hour session at the South African Scrum Gathering titled "Live your principles or stay in bed".  You can read the abstract <a href="http://www.scrum.org.za/gathering-2/speaker-information">here</a>.  In my opinion, there is far too little focus on software development itself in Scrum.  So, this is unashamedly a developer session.  I will be present various snippets of code, and we will "live our principles" to transform the code into something that is less messy.
I often hear developers, and managers too, saying "It's so much easier without, so why bother?".  Well, design is hard.  Applying principles for life is harder.  But if you are professional developer and have a conscience about your design, your code, and your product then "an easy life without principles" is not an option.</p>
<p>If you are planning to come along, bring your laptop with your development environment.  I will likely have code samples in Java, C#, Ruby, Javascript, and even, yup, Basic (well, maybe).  All the samples should be very readable and you could easily translate them to something equivalent in your language pretty easily.  Better still, bring some of your own code along, that you want to share.</p>
<p>In reality, this is stuff that Scrum does not teach you, but need to know to avoid Scrum burnout.  Looking back, I should have done something like this sooner.</p>
]]></description></item><item><title>Upcoming talks</title><category>Conferences</category><dc:creator>Aslam</dc:creator><pubDate>Thu, 11 Aug 2011 22:36:07 +0000</pubDate><link>http://f3yourmind.net/blog/events/upcoming-talks</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081491e4b03ccef5787548</guid><description><![CDATA[<p>I've got a busy few weeks of preparation to get through for a few talks that I will be giving.  In September I will be speaking at the <a target="_blank" href="http://www.scrum.org.za/gathering-2/speaker-information">South African Scrum Gathering</a>.  The one talk for Johannesburg is on product ownership and it is a combination of the content that I presented earlier for the SD Times webinars.  The other I hope to keep quite code centric and is aimed squarely at developers and architects.
Then in November, I've been kindly invited to speak at <a target="_blank" href="http://oredev.org/2011/speakers/aslam-khan">Oredev</a> in Malmo, Sweden.  I will be talking on the Java track and Architecture track.  Being in Sweden, I get a chance to get some face time with my Scandinavian colleagues, and lots of offshore geek friends.  If you are a South African looking for a decent developer conference, then consider Oredev.  It has a good vibe and some very good content, and is generally good value for money.</p>
]]></description></item><item><title>Lean Software Development Webinar</title><category>Conferences</category><dc:creator>Aslam</dc:creator><pubDate>Wed, 13 Jul 2011 00:09:52 +0000</pubDate><link>http://f3yourmind.net/blog/events/lean-software-development-webinar</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081491e4b03ccef5787545</guid><description><![CDATA[<p>I will be joining <a href="http://www.threeriversinstitute.org/blog/">Kent Beck</a> and <a href="http://blog.crisp.se/henrikkniberg">Henrik Kniberg</a> on July 20, 2011 for an <a href="http://www.sdtimes.com/content/resources.aspx?ShowOnlyResourceID=495">SD Times webinar</a> on Lean Software Development.  As usual, Kent has put up a great abstract for the event.  I'm absolutely certain that Kent will set the scene with his usual deep insights, and Henrik  has some amazing "from the trenches" experiential material to share.  Overall, we will explore this concept of waste vs value and how lean influences application development.
Personally, I want to cover what flow and waste mean to me, and examples of the huge piles of waste that I ended up manufacturing or walking into blindly and then struggling to dig myself out at great expense.  If the time allows, I want to weave in some models of flow that work for me and those that contributed to waste.  All of this fits into my rather weak thoughts on designing feedback loops.</p>
<p>&nbsp;</p>
]]></description></item><item><title>You did what with your ESB!?</title><category>Software Development</category><dc:creator>Aslam</dc:creator><pubDate>Tue, 14 Jun 2011 19:29:16 +0000</pubDate><link>http://f3yourmind.net/blog/software-development/you-did-what-with-your-esb</link><guid isPermaLink="false">5006a671e4b09ef2252cfad4:50081442e4b03ccef57870b3:50081490e4b03ccef5787542</guid><description><![CDATA[<p>I’ve seen many enterprise service bus (ESB) implementations that are, well, quite extraordinary.  Sadly, they are extraordinary for more wrong reasons than right.  Given that we had a SOA frenzy not too long ago, many developers got caught in that feeding frenzy.  Hey, when you’re a shark off the south coast of Kwazulu-Natal in winter, everything looks like a sardine.  In fact, if you were a tiny sole, just wandering around at the bottom of a big sea, chances are you also wanted some of them some sardines.
That was a long time ago, but now that we get to see the extraordinary things that developers built with their ESB.  Here are my top five extraordinary things.</p>
<p><strong>#5 Look, we can synchronize our databases with our ESB</strong></p>
<p>You have two application databases and you want the changes in one to be propagated to the other.  The ESB seemed like a perfect way to spray data around.  Hey, just give me an end point and I'd pump some data through it.  Well, syncing data is a replication problem with different challenges such as change detection, conflict resolution, retry or abort strategies, and bulk materialization on both ends when things get horribly out of sync.</p>
<p><strong>#4 You can call my stored proc from the other side of my ESB</strong></p>
<p>Somewhere in your app you had something that called a stored procedure. The ESB seemed like a really easy way to wrap that SProc with a service and hand out a new end point.  Cool, now everyone can call your stored proc.  Well, perhaps that original thing that was calling your stored proc was a wrong architecture decision in the first place.  If it was the write decision, suddenly opening it up to multiple callers that you have no control over means you got to be certain about whether your SProc is re-entrant, can handle the concurrency, and a whole lot more.  <strong>
</strong></p>
<p><strong>#3 My ESB now manages my transactions</strong></p>
<p>Enough said.</p>
<p><strong>#2 My authentication runs as a centralized service on my ESB</strong></p>
<p>Login seems like an easy enough "hello world" service to get up and running.  Hey, since our ESB has all of these apps hanging off it, we can get our Login Service to do single sign on (SSO).  We just need to call all the login services for each app and front it with our single sign on service and then this service will dish out authentication tokens.  Oh, we might as well put in a centralised authorisation service too.  Well, firstly, login is not a service.  You can take that thought further from here.</p>
<p><strong>#1 I replaced my call stack with my ESB</strong></p>
<p>To be fair, most developers don't know that they did this.  Let me explain.  You had some app that called a method that calls a few more methods and so on.  We all know that this builds up a call stack that gets popped on the return path.  When you take those classes that have those methods and dump them as services on your ESB, the call stack has not changed, but now there is an ESB in between.  Well, you can't just shift classes wrapped as services to your ESB.  You actually have to get service oriented in your architecture.  Only then will that call stack change.</p>
<p>It's not surprising that we see this now.  It takes a long time for an architectural style to be understood.  Unfortunately, there are some costly mistakes along the way.  We also can't blame the ESB, but, beware, the sardine run happens every year.</p>
]]></description></item></channel></rss>