Dave Boster

How Fascinating! \(๏◡๏)/

Thoughts

Incidental and Informal Learning Theory

Discussing with a colleague how we have been iterating on “Tech Talks” within our development teams (future backlink should go here), I learned there’s a theory for it called “Incidental and Informal Learning.” For now, I’ve included a section below to give a brief on a tech talk.

How fascinating! \(๏◡๏)/

What is Informal Learning?

There’s an article from Emma O’Neill on LearnUpon.com that answers this question, What is Informal Learning?.

More to come as I unpack this.

‘Tech Talk’ Brief

Our goal was to help with the understanding and adoption of Test-Driven Development (TDD). We started by licensing videos from Uncle Bob (Robert C. Martin) and his fanstatic Clean Coders website and then held an internal “Tech Talk” with an internal group of developers.

I love to iterate and discover, so through a series of “tech talks,” we came to the following format:

  • Length: 2 hours (120 minutes)
  • Split video into three segments, each segment consisting of:
    • Watch the video together (15-20 mins)
    • Split into random-ish breakout groups (no more than 5-6 per group) (10-15 mins)
      • go around the group and share 1-3 things that came to mind; “skepticism is encouraged”
      • have a group representative either remember (or write down) a few points to bring back to the larger group.
    • Come back together and have each group share the “gist” of their conversation (great if you can share it in chat as well)
  • Wrap-up (5-10mins) - what’s a “how fascinating!” moment or takeaway, and any action over the next two weeks as a result?
[ education  tech-talks  leadership  development-management  ]

Developer Blogs

Blog post Your words are wasted from Scott Hanselman’s blog on August 19, 2012.

Takeaways

  • Developers should be blogging.
  • Developers who blog, could probably be posting more.
  • Content should be open to the Nets; not restricted to “walled gardens” (internal company sites or platforms like Twitter?).
  • Developer content is the “Engine of the Community.”

Questions

  • What bright spots can come from these recommendations?
  • Does blogging help developers focus on the “how” over the “what”?
    • i.e. discussing what was fascinating or insightful, versus just showing that something can be done and move on.
  • Can this help developers with learning and mastery of their craft?
  • Would this help developers get more comfortable with openness, transparency, and vulnerability?
  • Could this make us better communicators?
[ developer-blogs  honing-craft  communication  ]

Engineering Leadership

After our small (but mighty) five-person software company, NewFire Group, decided to join a much larger organization with a matching vision and mission, it wasn’t long before I asked myself, “What am I supposed to do as a Development Manager?”.

What is it I’m supposed to do?

As a software developer and small business owner, I thought I had nailed down the essentials for managing a team of talented software developers.

  • We developed a great hiring process, based on the book “Who: The A Method of Hiring” by Dr. Geoff Smart and Randy Street.
  • We had established a career path and salary expectations based on ​the great work and generosity of Paul Stovell at Octopus Deploy.​
    • Note: while the original blog post is no longer available, Paul and Octopus Deploy still make public their Career & Compensation policies online in the Octopus Handbook.

I began to realize that what got me here, wasn’t going to be all I needed to get where I was going. It was a struggle, to say the least, but a starting point for something new. I was now part of an amazing organization, which emphasized trust and respect, servant leadership, transparency, and learning.

In the middle of this struggle, Dave Royce sent me a link to a video about Development Management. This one video has led to so many wonderful things. This amazing presentation has helped me frame my thoughts around development leadership at a large organization and discover the CircleCI Engineering Competency Matrix. Thank you, Dave!!

What Engineering Managers Should Do (and Why We Don’t) • Lena Reinhard • GOTO 2019

CircleCI Engineering Competency Matrix

At the end of Lana’s presentation, there’s a link to their CircleCI Competency Matrix. Lana describes in the article, “Why we re-designed our engineering career paths at CircleCI”, CircleCI Blog, 11-Dec-2018, how they had created the matrix three years earlier and had recently updated it to reflect their growth and lessons learned.

Two thoughts struck me:

  1. The level of transparency, generosity, and strategy from the CircleCI leadership team to share their matrix with the world (via Creative Commons Attribution 4.0).
  2. The sheer difficulty for any organizaton to create something and not just call it “good enough” and move on; to do self-reflection, iterate on what you learned, and then share it with the world.

I took both the previous Career Path & Salary Espectations paragraphs we had and the CircleCI matrix and I did a very humbling deep-dive into the very phrasing of each matrix level. Don’t let the briviety deceive you. Unpacking each sentence is like uncompressing a highly-efficient, and very large, archive file. It’s a lot of work and I found more humbling than reading and reflecting on The Programmer’s Oath, by Robert “Uncle Bob” Martin from November 2015.

side-note I highly recommend Uncle Bob’s most recent update, Clean Code Episode 45: The Programmer’s Oath.

Thought Backlog

An outline of additional thoughts I have for this topic that may get added to this post in the future.

  • Iterative process for introducing it, by facilitating discussions, learning, and reflection (encouraging skepticism and questioning).
  • Use as an individual developer to provide an employer agnostic career development guide or tool.
  • Onboarding Process - Iteration 3 (2023)
  • Boster.dev - thought transparency (show versions of thoughts iterated over time, change log, feed, etc.)

Onboarding Process - Iteration 3

Process

  1. understanding / learning / reflection
  2. self assessment
  3. servant leader assessment
  4. review / feedback / coaching
  5. individual development planning (team member-driven, leader-supported)

Details / Thoughts:

  • Provide a copy for personal use; feel free to use it throughout career in software (if useful)
  • Read through it, write questions down, research topics, and reconcile with current understanding and experience.
    • Sketicism is encouraged.
    • What do the words mean? What pictures do you see?
  • Schedule a 1-1 to talk through each competency.
    • Trust is important, otherwise they may feel reluctant to have an open conversation about what they know/don’t know, done/have not done.
    • This conversation is about establishing a relationship, connecting, and sharing knowledge both ways.
    • Important to share this is like a maturity model in that people in higher job titles may have some lower level compentencies and vice versa.
      • It all depends on individuals, their backgrounds, previous opporunities, etc.
      • This to help people grow and learn, not to demote them.
    • It takes a few meetings to get through it.
      • Plan for one program increment (1 quarter / 3 months).
  • Self Assessment
    • Highlight green for completed and yellow for areas of focus, but try to limit yellow to only 1-3.
    • Identify examples of what it means to have completed it or achieved it; consider proficiency vs mastery.

Year over year (only in second year of it), I’m helping document their growth in areas. It’s not about just checking a box, though, it’s about experiences and in some cases not everyone has the opportunity to level-up in a particular area.

[ development-management  competency-matrix  engineering-leadership  ]

Extreme Programming Projects

A process for starting a greenfield or proof-of-concept project using the principles of Extreme Programming. After the first iteration of Red-Green-Refactor, I want to establish an automated build pipeline, publish test results, and code coverage results.

Create a new repository for the Proof of Concept.

Basic process

  1. Using Test-Driven Development (TDD), complete first Red-Green-Refactor; push to changes.
  2. Create initial pipeline to build project; push changes;
  3. Require successful build for Pull Requests into Main branch.
  4. Add unit test results to pipeline.
  5. Add test coverage to pipeline.
  6. Continue TDD.

Add Presentation/Service Layer

  1. Start with the basic process
  2. Add continuous deployment to pipeline.
  3. Continue TDD

Add Persistent Storage

  1. Start with the basic process
  2. Add continuous deployment to pipeline.
  3. Continue TDD
[ development-process  extreme-programming  build-pipelines  ]

My Programmer's Oath

Objective is to provide a public statement to state my aspiration and values similar to Robert “Uncle Bob” Martin’s Programmer’s Oath, on his Clean Coder Blog, in November 2015.

The Start

I realized I’ve been working on this idea though a variety of documents, tech talks, job postings, and profile descriptions.

I am committed to the continual learning and improvement of my craft as a Software Development Professional through the relentless pursuit of mastery in Extreme Programming (XP) principles of Test-Drive Development (TDD), Refactoring, Pairing, and Simple Design, and Clean Coding practices.

I want to use my time in this profession, to find ways of applying software and technology to worthy aspirations to help us be more human, more effective, and more intentional!

That’s a start, but there is plenty more to dig through.

Reflecting on the Original Oath

As I work through this thought process, I want to go through each of Martin’s original statements, documenting thoughts and questions with each reflection. Thinking about these as words we could offer as a promise to the world.

I will not produce harmful code.

Placeholder to elaborate…

The code that I produce will always be my best work. I will not knowingly allow code that is defective either in behavior or structure to accumulate.

Placeholder to elaborate…

I will produce, with each release, a quick, sure, and repeatable proof that every element of the code works as it should.

Placeholder to elaborate…

I will make frequent, small, releases so that I do not impede the progress of others.

Placeholder to elaborate…

I will fearlessly and relentlessly improve my creations at every opportunity. I will never degrade them.

Placeholder to elaborate…

I will do all that I can to keep the productivity of myself, and others, as high as possible. I will do nothing that decreases that productivity.

Placeholder to elaborate…

I will continuously ensure that others can cover for me, and that I can cover for them.

Placeholder to elaborate…

I will produce estimates that are honest both in magnitude and precision. I will not make promises without certainty.

Placeholder to elaborate…

I will never stop learning and improving my craft.

Placeholder to elaborate…

I will continuously ensure others can cover for me, and that I can cover for them.

Elaborations:

  • I will not create overly complicated code that cannot be maintained by others.
  • I will create code that can safely and efficiently be maintained and enhanced by others after I stop working on this codebase.

Thought Backstage

A place to put information as I work on this particular thought to help with organization.

Questions / Backlog

  • What if we had a “Programmer’s Warranty” that made a coder responsible for their code, even after employment?
  • Would that cause programmers to change how they work or make it easier to abide by the oath (skin in the game)?
  • Transparency: how I write my code, what resources I use, do I use machine learning, coding assistance from GitHub Copilot, ChatGPT, third party libraries like Resharper, Intellisense, etc.
  • How to address that most people appear to take on jobs or titles that are challenging, offer growth, and not necessarily that they have mastered? This causes conflict with getting into situations without having “done this before”.
    • When higher-level developers, architects, and leadership “try, but fail” is too tempting to find another job, abandon those who they were leading, and “try again.” Much harder and more painful to deal with the mess and then decide whether to move on.

Resources and References

[ development-management  programmers-oath  software-professional  ]

Quote Origin: Just because you can...

“Just because you can, doesn’t mean you should.” – unknown

This quote or phrase is probably my most used when discussing technology, especially software development. I’ve marked it as “unknown” because I’m not exactly sure where I picked it up or to whom it is attributed.

As part of some great leadership training over the last few years, I now understand why it’s important to understand and think about the origins of the quotes and phrases we use.

Findings

HBR: Just because you can, doesn’t mean you should by Bill Taylor, December 16, 2011.

  • Article about the banking industry, ethics, etc.
  • Maybe these lessons of our not-so-distant-past are not being fully understood 🤔

Google is featuring (recommending) the GoodReads attribution to Sherrilyn Kenyon.

  • not much information on this page regarding its source.
[ quote-origin  communication  developer-quote  ]