Skip to main content

Granularity Familiarity

 

I saw Maaret's Pyhäjärvi's post on LinkedIn  the other day. This line chimed strongly with me:
Sense of lack of time. Someone asked how to have joy of discovery when feeling always pinched with time. We have in many cases lost control over time, and I have done work I have not necessarily appreciated on making time flexible - always seeing there is a next day and having no schedules and small slices of work.
I feel like I do my work at various granularities across multiple dimensions and so, to begin to get this idea straight in my head, I tried to list some of them.

It was harder than I thought it would be because so much of this is instinctive, intuitive, and in the moment. Given that, here goes draft 0.1. Hopefully I'll begin to feel more familiar with the idea and be able to revise the model later on.

Scope

Parcel of work. My team's practices are reasonably common, I think. Tasks are portioned into into Jira tickets which progress out of a backlog through various states of refinement, into states of being worked on, and then into the state of being done. Perhaps less common is that there is no explicit state of being tested. 

My testing, and other work, can happen anywhere from sub-ticket, through the ticket itself, across multiple tickets, or outside of any ticket. Additionally, I don't test the work in every ticket.

Learning. Some tasks offer the chance to grow my knowledge and sometimes the constraints mean that learning is not a priority. Given free choice, though, I like to sit at the upper end of the learning scale, picking up what I can whenever I can. This means that I'll try new ways to accomplish understood tasks and take on tasks that I don't know how to do, just for the learning opportunity.

Breadth and depth. The direction I take an investigation varies greatly. I might see that some big new project is coming up and dedicate a few hours to understanding the domain it sits in before there is even a ticket. I think of this as a broad, landscaping, task. I want to know the big pieces, how they relate to one another, the shapes of existing solutions, the terminology that's typically used, and so on.

Deep work could be done while trying to track down, for example, an intermittent customer issue in production. There are typically many variables to consider and they might interact so I'll be looking at multiple techniques and repeated experiments to get an idea of what's going on. 

In contrast, sometimes a code review will be sufficient shallow and narrow testing.

Tech stack. The main service my team works on consumes components made by other teams and is a dependency for components owned by other teams. I look for ways to test at all of the levels in that stack. When we make changes in our service, I might test only against it,  up the stack, down the stack, or end-to-end with observation wherever I think it's interesting and possible.

People

Collaborators. I don't do all of this work by myself. I do work alone, but I also spend profitable and enjoyable time pairing with others, in small groups, in my team and cross-team.

Impact. Where will the outcome of this work be experienced? It is just for me, a colleague, my team, the group my team sits in, somewhere else in the company? I can think about the work I am doing and see where else I think it makes sense to share. 

At Ada we have Community Days every couple of weeks and they are a convenient way to share by broadcasting although the location of the impact is hard to predict that way. I use my personal Confluence page to keep a list of internal presentations I've done so they can have the same kind of impact at other timescales. 

I think about the work I've done and try to find people or teams that I can make contact with to share it. I talk about my work to colleagues, looking for people they recommend might like to hear about it. This isn't egotistical. It's about finding like-minded people who care to do good work in the same space as me.

Relationship building.  I build relationships with others. I ask for help from others. I make myself available to help others. Actually, I actively look for ways in which I can help others. I keep an eye open for things that others do that could be helpful to me. I share results that I have found with people I think will be interested. Different activities give the opportunity to develop relationships to different extents, from simply making first contact, through adding a new layer, to making a radical change.

I joined the coffee chat rota in my first week at work and am now, 18 months later, starting to meet people for the second time. Some of them I have not spoken to since the first virtual cuppa, but others have been valuable contacts when I've needed something or vice versa.

You might say that a coffee chat is not work, and you'd probably be right. However, it is a small relationship investment, a small time investment, a low-risk investment with a potential longer-term payoff.

Time

Stake. What kind of gamble am I prepared to take on this piece of work? The stakes can be effort, annoyance or inconvenience to others, cashing in credit earned, IOUs, time spent, opportunity cost, delay, and so on. I wonder how I can reduce the stakes and with what kind of trade-offs.

Level of effort. I can spend from no time, to a few minutes, hours, days, or even weeks testing a thing. Depending on how you care to group activities, I have had single investigations that have lasted months.

To payoff. I start tasks that I expect will pay off now, this sprint, in the medium or long term, or that are only spikes or proofs-of-concept that I understand might not pay off at all. All actions are gambles and I tend to take smaller, more incremental steps (reduced scope, less time, lower risk) to reduce my risk when the potential reward is less well understood.

A task that pays off now might be some basic checking of a small fix that went through today, where I already understand the issues. At the other end of the spectrum, I've been working for over a year on weekly ensemble testing with a group of medical doctors in my company. There's no set agenda for this, we bring a topic to the Friday afternoon sessions and then work on it together.

I am sharing my knowledge, approaches, insights, tooling, connections and so on. How, when, and where this will bring benefit is very hard to judge. The participants all find value in it, so we keep going.

vs Ticket status. I can test while a ticket is in the backlog, in development, in review, and in production. Where a ticket is in its life-cycle is not the only factor in whether I am looking at the area.

Reflections

This is a first-cut, and I have thoughts that I don't know what to do with. Here's some:
  • When I start, I don't always know what granularity I will work at.
  • The work evolves in these dimensions (and probably others) as I learn about it.
  • When I externalise the idea of relationship-building I feel like it might be perceived of as manipulative. Perhaps I can find a better way to describe it.
  • I am not very granular when it comes to visibility. I will pretty much always talk about what I'm trying and, because I'm an inveterate note keeper, there will be notes in public.
  • I typically track my work as threads. Any given investigation may be more than one thread.
  • Some work impacts on people and process more than product. I'm not sure the model reflects that.
  • How do I get to work this way when others feel the tyranny of tickets? I believe I have built the trust of the teams I work in.

Comments

Popular posts from this blog

Meet Me Halfway?

  The Association for Software Testing is crowd-sourcing a book,  Navigating the World as a Context-Driven Tester , which aims to provide  responses to common questions and statements about testing from a  context-driven perspective . It's being edited by  Lee Hawkins  who is  posing questions on  Twitter ,   LinkedIn , Mastodon , Slack , and the AST  mailing list  and then collating the replies, focusing on practice over theory. I've decided to  contribute  by answering briefly, and without a lot of editing or crafting, by imagining that I'm speaking to someone in software development who's acting in good faith, cares about their work and mine, but doesn't have much visibility of what testing can be. Perhaps you'd like to join me?   --00-- "Stop answering my questions with questions." Sure, I can do that. In return, please stop asking me questions so open to interpretation that any answ...

Can Code, Can't Code, Is Useful

The Association for Software Testing is crowd-sourcing a book,  Navigating the World as a Context-Driven Tester , which aims to provide  responses to common questions and statements about testing from a  context-driven perspective . It's being edited by  Lee Hawkins  who is  posing questions on  Twitter ,   LinkedIn , Mastodon , Slack , and the AST  mailing list  and then collating the replies, focusing on practice over theory. I've decided to  contribute  by answering briefly, and without a lot of editing or crafting, by imagining that I'm speaking to someone in software development who's acting in good faith, cares about their work and mine, but doesn't have much visibility of what testing can be. Perhaps you'd like to join me?   --00-- "If testers can’t code, they’re of no use to us" My first reaction is to wonder what you expect from your testers. I am immediately interested ...

The Best Programmer Dan Knows

  I was pairing with my friend Vernon at work last week, on a tool I've been developing. He was smiling broadly as I talked him through what I'd done because we've been here before. The tool facilitates a task that's time-consuming, inefficient, error-prone, tiresome, and important to get right. Vern knows that those kinds of factors trigger me to change or build something, and that's why he was struggling not to laugh out loud. He held himself together and asked a bunch of sensible questions about the need, the desired outcome, and the approach I'd taken. Then he mentioned a talk by Daniel Terhorst-North, called The Best Programmer I Know, and said that much of it paralleled what he sees me doing. It was my turn to laugh then, because I am not a good programmer, and I thought he knew that already. What I do accept, though, is that I am focussed on the value that programs can give, and getting some of that value as early as possible. He sent me a link to the ta...

Beginning Sketchnoting

In September 2017 I attended  Ian Johnson 's visual note-taking workshop at  DDD East Anglia . For the rest of the day I made sketchnotes, including during Karo Stoltzenburg 's talk on exploratory testing for developers  (sketch below), and since then I've been doing it on a regular basis. Karo recently asked whether I'd do a Team Eating (the Linguamatics brown bag lunch thing) on sketchnoting. I did, and this post captures some of what I said. Beginning sketchnoting, then. There's two sides to that: I still regard myself as a beginner at it, and today I'll give you some encouragement and some tips based on my experience, to begin sketchnoting for yourselves. I spend an enormous amount of time in situations where I find it helpful to take notes: testing, talking to colleagues about a problem, reading, 1-1 meetings, project meetings, workshops, conferences, and, and, and, and I could go on. I've long been interested in the approaches I've evol...

Not Strictly for the Birds

  One of my chores takes me outside early in the morning and, if I time it right, I get to hear a charming chorus of birdsong from the trees in the gardens down our road, a relaxing layered soundscape of tuneful calls, chatter, and chirrupping. Interestingly, although I can tell from the number and variety of trills that there must be a large number of birds around, they are tricky to spot. I have found that by staring loosely at something, such as the silhouette of a tree's crown against the slowly brightening sky, I see more birds out of the corner of my eye than if I scan to look for them. The reason seems to be that my peripheral vision picks up movement against the wider background that direct inspection can miss. An optometrist I am not, but I do find myself staring at data a great deal, seeking relationships, patterns, or gaps. I idly wondered whether, if I filled my visual field with data, I might be able to exploit my peripheral vision in that quest. I have a wide monito...

ChatGPTesters

The Association for Software Testing is crowd-sourcing a book,  Navigating the World as a Context-Driven Tester , which aims to provide  responses to common questions and statements about testing from a  context-driven perspective . It's being edited by  Lee Hawkins  who is  posing questions on  Twitter ,   LinkedIn , Mastodon , Slack , and the AST  mailing list  and then collating the replies, focusing on practice over theory. I've decided to  contribute  by answering briefly, and without a lot of editing or crafting, by imagining that I'm speaking to someone in software development who's acting in good faith, cares about their work and mine, but doesn't have much visibility of what testing can be. Perhaps you'd like to join me?   --00--  "Why don’t we replace the testers with AI?" We have a good relationship so I feel safe telling you that my instinctive reaction, as a member of the T...

Don't Know? Find Out!

In What We Know We Don't Know , Hillel Wayne crisply summarises a handful of research findings about software development, describes how the research is carried out and reviewed and how he explores it, and contrasts those evidence-based results with the pronouncements of charismatic thought leaders. He also notes how and why this kind of research is hard in the software world. I won't pull much from the talk because I want to encourage you to watch it. Go on, it's reasonably short, it's comprehensible for me at 1.25x, and you can skip the section on Domain-Driven Design (the talk was at DDD Europe) if that's not your bag. Let me just give the same example that he opens with: research shows that most code reviews focus more on the first file presented to reviewers rather than the most important file in the eye of the developer. What we should learn: flag the starting and other critical files to receive more productive reviews. You never even thought about that possi...

Vanilla Flavour Testing

I have been pairing with a new developer colleague recently. In our last session he asked me "is this normal testing?" saying that he'd never seen anything like it anywhere else that he'd worked. We finished the task we were on and then chatted about his question for a few minutes. This is a short summary of what I said. I would describe myself as context-driven . I don't take the same approach to testing every time, except in a meta way. I try to understand the important questions, who they are important to, and what the constraints on the work are. With that knowledge I look for productive, pragmatic, ways to explore whatever we're looking at to uncover valuable information or find a way to move on. I write test notes as I work in a format that I have found to be useful to me, colleagues, and stakeholders. For me, the notes should clearly state the mission and give a tl;dr summary of the findings and I like them to be public while I'm working not just w...

Express, Listen, and Field

Last weekend I participated in the LLandegfan Exploratory Workshop on Testing (LLEWT) 2024, a peer conference in a small parish hall on Anglesey, north Wales. The topic was communication and I shared my sketchnotes and a mind map from the day a few days ago. This post summarises my experience report.  Express, Listen, and Field Just about the most hands-on, practical, and valuable training I have ever done was on assertiveness with a local Cambridge coach, Laura Dain . In it she introduced Express, Listen, and Field (ELF), distilled from her experience across many years in the women’s movement, business, and academia.  ELF: say your key message clearly and calmly, actively listen to the response, and then focus only on what is relevant to your needs. I blogged a little about it back in 2017 and I've been using it ever since. Assertiveness In a previous role, I was the manager of a test team and organised training for the whole ...

The Best Laid Test Plans

The Association for Software Testing is crowd-sourcing a book,  Navigating the World as a Context-Driven Tester , which aims to provide  responses to common questions and statements about testing from a  context-driven perspective . It's being edited by  Lee Hawkins  who is  posing questions on  Twitter ,   LinkedIn , Mastodon , Slack , and the AST  mailing list  and then collating the replies, focusing on practice over theory. I've decided to  contribute  by answering briefly, and without a lot of editing or crafting, by imagining that I'm speaking to someone in software development who's acting in good faith, cares about their work and mine, but doesn't have much visibility of what testing can be. Perhaps you'd like to join me?   --00-- "What's the best format for a test plan?" I'll side-step the conversation about what a test plan is and just say that the format you should use is one th...