Log in

goodpods headphones icon

To access all our features

Open the Goodpods app
Close icon
iteration - Tracer bullets

Tracer bullets

iteration

05/11/18 • 29 min

plus icon
bookmark
Share icon

Chapter 2 - A Pragmatic Approach

Overview = combine ideas and processes

  1. duplicate knowledge throughout systems
  2. don't split any one piece of knowledge across multiple system components (orthogonality)
  3. insulate projects from their changing environments
  4. gather requirements and implement code at the same time
  5. how to give project estimates

This chapter is truly about a "pragmatic" approach to development


Tip 11: Don't Repeat Yourself

  • if you change one, you'll have to change another

Duplicated code arises differently:

  1. imposed: devs feel they have no choice
  2. inadvertent: devs don't realize they are duplicating
  3. impatient: devs got lazy because it seems easier
  4. interdeveloper: multiple people on a team duplicate a piece of info

we call these the "four i's"

  • "shortcuts make for long delays"
  • number 4 is a result of large teams - not having a --- dare I say --- a ubiquitous language
  • you need good communication to quell number 4
  • READ DOCS
  • Tip: Lean on code and programmatically generated things to prevent repeating yourself.

Tip 12: Make it easy to reuse

  • you want to create an environment where it's easier to find and reuse existing stuff so people don't have to go out and create their own
  • orthogonality
  • borrowed from geometry
  • two lines are orthogonal if they meet at right angles - think axes on a graph
  • move along (or parallel to the x-axis) and theres no change to the y-axis
  • in computing, "orthogonality" has come to mean independence / decoupling

TWO OR MORE THINGS are orthogonal if changes in one do not affect any of the others

i.e. database code will be orthogonal to the UI. you can change the interface without affecting the database

driving stick shift is not orthogonal
helicopter controls are not orthogonal

bottom line: non-orthogonal systems are hard to maintain


Tip 13: Eliminate Effects Between Unrelated things

  • design components that are self-contained. this is very much the case for react components.
  • and for ruby methods
  • and for js functions
  • you want: independent, single, well defined components
  • you want: single, independent components that don't need no man

You get two major benefits if you write orthogonal systems: increased productivity and reduced risk.

ways orthogonality can be applied to your work

  • teams can be more efficient if each major infrastructure component gets its own subteam: database, communications interface, middleware layer, etc
  • non orthogonal systems lead to bickering teams
  • system design: should be composed of a set of cooperating modules, each of which implements functionality independent of others
  • inherently, i think MVC is orthogonal
  • the flux pattern is also orthogonal in react applications. i think? ask yourself:

if i dramatically change the requirements behind a particular function, how many modules are affected?

Toolkits and Libraries

  • we're talking Ruby gems, Node modules, etc
  • choose technologies wisely

Testing

An orthogonally designed and implemented system is easier to test. Because the interactions between the system's components are formalized and limited, more of the system testing can be performed at the individual module level. This is good news, because module level (or unit) testing is considerably easier to specify and perform than integration testing.

  • building unit tests is a TEST of orthogonality.
  • easy unit tests == orthogonal

Reversability

Nothing is more dangerous than an idea if it's the only one you have.

Writing more orthogonal code allows you to more easily reverse changess or eb and flow with the needs of the project.

Bottom line: orthognality is about reduction of interdependency among system components


Tip 14: There are no final decisions

  • problem: critical decisions aren't easily reversable
  • imagine switching a codebase to use Mongo after having tens of thousands of records in a Postgres db
  • HOWEVER - if you REALLY abstracted the idea of a "database" out - you should have the flexibility to make that change, should you need to
  • you SHOULD prepare for contingencies

instead of carving decisions in stone, think of them mroe as being written in the sand at the beach. A big wave can come along and wipe them out at any time.

  • this is also why i love the Adapter pattern.
  • for example - making a folder called "Adapters" when making external http requests in a...

05/11/18 • 29 min

plus icon
bookmark
Share icon

Generate a badge

Get a badge for your website that links back to this episode

Select type & size
Open dropdown icon
share badge image

<a href="https://goodpods.com/podcasts/iteration-225636/tracer-bullets-25584534"> <img src="https://storage.googleapis.com/goodpods-images-bucket/badges/generic-badge-1.svg" alt="listen to tracer bullets on goodpods" style="width: 225px" /> </a>

Copy