23 comments

  • carlos-menezes 12 hours ago

    Congratulations on the launch.

    While I appreciate the effort put into development, I have some questions about the underlying premise.

    1. How do detailed metrics about coding sessions, git interactions, and test runs actually leads to meaningful improvements in your productivity?

    2. Assuming you have used this plugin for a while now, how does tracking these metrics correlate with better code quality?

    I hope I'm not coming across as overly critical, as that's not my intent. I appreciate the effort put into the development of software regardless of the final intent.

    • emhauck 12 hours ago

      Yes, these are great questions!

      When I look at my own experiences, I wouldn’t focus strictly on code quality and productivity in the narrow sense. What I mean by that is that my focus on smaller commits and smaller branches helped team members understand changes more quickly, making knowledge transfer easier. For branches where code reviews/approvals were necessary, this helped our overall flow because stories were not blocked that long due to long-lasting approvals.

      Another point was that, with Kasama, I was able to track the runtime of long-running tests and build tasks, which allowed me to point at tasks where optimizations were needed. Otherwise, such discussions were always based on gut feelings, and improvements were usually postponed…

  • jackedEngineer 7 hours ago

    Congratulations on launch. But I don't like when number of hours is used to quantify my work. Because x hours of work is not necessarily a good representation of complexity / quality of work. Even the number of commits is not a good metric. I want to know what HN thinks and how they measure their productivity?

  • hk1337 5 hours ago

    If this turns into some sort of hiring metric, I’m gong to be pissed.

    > What’s your Kasama score?

  • ianeigorndua 8 hours ago

    It would be interesting if this also hooked into an AST to capture different syntaxes and structures used to express procedures and entities in code.

  • lawgimenez 5 hours ago

    I’m curious on how you came up with the name? In my language it means companion.

  • ricc 12 hours ago

    Was this named after the Tagalog word?

    • treypitt 5 hours ago

      Holla, swear to my kasamas When I grow up I wanna be just like Yuri Kochiyama.

    • emhauck 11 hours ago

      Yes, well noticed!

      • ricc 11 hours ago

        That’s quite easy for me because I’m Filipino! And coincidentally, I’m also residing in Germany. :D

      • sakesun 5 hours ago

        It's a legible Thai name as well.

      • felixnm 11 hours ago

        Mabuhay! We also have a Michelin starred restaurant here in Chicago with the same name.

        • lawgimenez 5 hours ago

          The same restaurant that was featured in the tv series The Bear right?

  • dewey 13 hours ago

    How actionable will these insights be? Are you going to write better code because you don't want your "failed test" metric to go down?

    As with many of these "quantified self" stats it feels like it will result in a colorful and nice to look at dashboard...with no benefit.

    • hirako2000 11 hours ago

      These "quantified self" stats provide countless insights.

      One example.

      There is a refactoring view in there. By time, by projects, even breaking the figures down by type of actions.

      Benefits:

      - Self awareness. It is hard to gauge how much time is spent refactoring. If your priority isn't to refactor but meet a soon coming deadline, these stats tell you whether you are adhering to the priorities.

      - Quantifies. If you are trying to explain to your colleagues that you find yourself needing to do a lot of refactor for that particular project, you've got numbers to communicate. What's a lot? Some colleagues often ask.

      - Evidence. Showing these numbers communicates better certainty than "I think I've been doing a lot of refactor on this project today"

      Plus, oftentimes with visualisations, we don't know what we are looking for. Until we find it.

    • emhauck 13 hours ago

      Yes, metrics alone are not sufficient here. But I did not want to include opinionated targets where optimization towards might be problematic.

      For me, I had 2 reasons to look at the metrics: First, I wanted to split my work into smaller chunks and commit more often, and I wanted to track whether I achieved this goal. Second, it occurred to me that I was using some IDE refactorings a lot of times, but I was wondering where my „blind spots“ where, i.e which types of refactorings I was using rarely or wasn’t even aware of. This inspired me to track IDE refactorings in the plugin as well.

      However, there might still be the use case of some kind of „trainers“ that could be included in the plugin that help you improving your coding. Running tests more often, continuously integrating your branches, committing more often - these are not silver bullet mechanisms, but they do make sense a lot of times and a tool might help here.

    • Ragnarork 13 hours ago

      > How actionable will these insights be?

      I mean, that's something you should try to answer yourself, if you think you can extract any benefit from having these stats.

      To me it's similar to a fitness app that can tell you things like time, speed, distance, elevation, but won't really tell you how to run better.

      I have a hard time coming up with ways this could help my coding habits right away, but I think this would be on the user to find these, not the stats reporting tool, no? And if you find no real use, then it's maybe just not for you.

    • latchkey 13 hours ago

      It'll tell your boss if they should keep you around or replace you with AI.

      • xyst 12 hours ago

        1. Create local (or private remote repos) with similar name as remote repos in VCS

        2. Use scripts to commit junk to local or remote repos

        2a. Extra points if you use chatgpt, Claude, gemini beta alpha0 to generate junk commits

        3. ???

        4. Profit. Sit back for a few months or quarters. Interview for new jobs, and then bounce out of there

    • cratermoon 13 hours ago

      It's data. Creating a colorful dashboard turns it into information, To get knowledge and action is another step. The plug-in does what it says on the tin, it's up to the user to make something of it, or leave it as inert knowledge.

  • carterklein13 13 hours ago

    Do NOT show this to most managers

    • emhauck 13 hours ago

      No, but who is the one interested in your improving? :-)