<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: nrr</title><link>https://news.ycombinator.com/user?id=nrr</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Sun, 03 May 2026 21:06:28 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=nrr" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by nrr in "The FizzBuzz that did not get me the job"]]></title><description><![CDATA[
<p>Nothing.</p>
]]></description><pubDate>Sun, 26 Jan 2025 23:23:56 +0000</pubDate><link>https://news.ycombinator.com/item?id=42835389</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42835389</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42835389</guid></item><item><title><![CDATA[New comment by nrr in "The Mythical IO-Bound Rails App"]]></title><description><![CDATA[
<p>No, I left the industry.</p>
]]></description><pubDate>Sun, 26 Jan 2025 07:06:49 +0000</pubDate><link>https://news.ycombinator.com/item?id=42828317</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42828317</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42828317</guid></item><item><title><![CDATA[New comment by nrr in "File Explorer is merged to Helix editor"]]></title><description><![CDATA[
<p>dang seems to have outright banned him just over a fortnight ago. <a href="https://news.ycombinator.com/item?id=42653007">https://news.ycombinator.com/item?id=42653007</a><p>On Hacker News, banned accounts can still comment, but those comments are immediately dead until vouched.</p>
]]></description><pubDate>Sat, 25 Jan 2025 21:49:36 +0000</pubDate><link>https://news.ycombinator.com/item?id=42825205</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42825205</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42825205</guid></item><item><title><![CDATA[New comment by nrr in "The Mythical IO-Bound Rails App"]]></title><description><![CDATA[
<p>"There's no foresight. There's no planning." Couple that with "as an expression of agility," and it really rings true to me. I've worked in enough shops where the contractual obligations preclude any ability to slow down and put together a plan. A culture where you're forced to go from an angry phone call from the suits to something running in production in mere hours is a culture that finds building bookcases out of mashed potatoes acceptable.<p>The best environment I've ever worked in was, ironically enough, fully invested in Scrum, but it wasn't what's typical in the industry. Notably, we had no bug tracker[0], and for the most part, everyone was expected to work on one thing together[1]. We also spent an entire quarter out of the year doing nothing but planning, roleplaying, and actually working in the business problem domain. Once we got the plan together, the expectation was to proceed with it, with the steps executed in the order we agreed to, until we had to re-plan[2].<p>With the rituals built in for measuring and re-assessing whether our plan was the right one through, e.g., sprint retrospectives, we were generally able to work tomorrow's opportunity into the plan that we had. With the understanding that successfully delivering everything we'd promised at the end of the sprint was a coin toss, if we were succeeding a lot, it gave us the budget to blow a sprint or two on chasing FOMO and documenting what we learned.<p>0: How did we address bugs without a bug tracker? We had a support team that could pull our andon cord for us whenever they couldn't come up with a satisfactory workaround (based on how agonizing it was for everyone involved) to behavior that was causing someone a problem. Their workarounds got added to the product documentation, and we got a product backlog item, usually put at the top of the backlog so it'd be addressed in the next sprint, to make sure that the workaround was, e.g., tested enough such that it wouldn't break in subsequent revisions of the software. Bad enough bugs killed the sprint and sent us to re-plan. We tracked the product backlog with Excel.<p>1: Think pairing but scaled up. It's kinda cheesy at first, but with everyone working together like this, you really do get a lot done in a day, and mentoring comes for free.<p>2: As it went: Re-planning is re-work, and re-work is waste.</p>
]]></description><pubDate>Sat, 25 Jan 2025 20:55:14 +0000</pubDate><link>https://news.ycombinator.com/item?id=42824784</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42824784</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42824784</guid></item><item><title><![CDATA[New comment by nrr in "The FizzBuzz that did not get me the job"]]></title><description><![CDATA[
<p>I've had a lot of experiences like this, and I wound up ducking out of the industry entirely in 2021 after having had my skillset reduced to dogmatic use of the infrastructure buzzword of the day.</p>
]]></description><pubDate>Sat, 25 Jan 2025 19:23:30 +0000</pubDate><link>https://news.ycombinator.com/item?id=42823921</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42823921</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42823921</guid></item><item><title><![CDATA[New comment by nrr in "Poka-Yoke"]]></title><description><![CDATA[
<p>A lot of newer[0] US domestic market manual transmission cars do, in fact, have an interlock that prevents the starter motor from getting power without the clutch pedal also being depressed. Of particular note, my 1984 Ford Bronco II, 1991 Mitsubishi Galant, and 2004 Honda Accord all had such an interlock.<p>0: This is basically everything after the three-on-the-tree/four-on-the-floor era. I have yet to drive anything with an overdrive gear that didn't require popping the clutch to crank the starter.</p>
]]></description><pubDate>Thu, 09 Jan 2025 19:15:14 +0000</pubDate><link>https://news.ycombinator.com/item?id=42648905</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42648905</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42648905</guid></item><item><title><![CDATA[New comment by nrr in "Unemployed office workers are having a harder time finding new jobs"]]></title><description><![CDATA[
<p>Georgia HB 87 (2011) and its unintended consequences say otherwise. While the H-2A is indeed popular, there are still a staggering number of people working these jobs who are here illegally.<p><a href="https://www.forbes.com/sites/realspin/2012/05/17/the-law-of-unintended-consequences-georgias-immigration-law-backfires/" rel="nofollow">https://www.forbes.com/sites/realspin/2012/05/17/the-law-of-...</a><p><a href="https://www.npr.org/sections/thetwo-way/2011/05/27/136718112/georgia-farmers-say-immigration-law-keeps-workers-away" rel="nofollow">https://www.npr.org/sections/thetwo-way/2011/05/27/136718112...</a><p><a href="https://www.theatlantic.com/business/archive/2011/06/georgias-harsh-immigration-law-costs-millions-in-unharvested-crops/240774/" rel="nofollow">https://www.theatlantic.com/business/archive/2011/06/georgia...</a><p><a href="https://www.politico.com/story/2011/06/ga-immigrant-crackdown-backfires-057551" rel="nofollow">https://www.politico.com/story/2011/06/ga-immigrant-crackdow...</a><p><a href="https://www.timesfreepress.com/news/2013/jul/07/immigration-crackdown-2-years-later-georgia/" rel="nofollow">https://www.timesfreepress.com/news/2013/jul/07/immigration-...</a></p>
]]></description><pubDate>Mon, 06 Jan 2025 07:06:50 +0000</pubDate><link>https://news.ycombinator.com/item?id=42608412</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42608412</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42608412</guid></item><item><title><![CDATA[New comment by nrr in "Ask HN: What's Your Morning Routine?"]]></title><description><![CDATA[
<p>It's all part of the actuarial mindset. The entire point of the exercise is to arrive at a model of reality that has some degree of predictive power.<p>> For me the only things that scare me are in the "I have no data on that" category.<p>I feel exactly the same way. It means that I have no idea what those things will wind up costing me, and that's <i>the</i> anxiety trigger as far as I'm concerned.</p>
]]></description><pubDate>Thu, 02 Jan 2025 19:52:48 +0000</pubDate><link>https://news.ycombinator.com/item?id=42578086</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42578086</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42578086</guid></item><item><title><![CDATA[New comment by nrr in "Ask HN: What's Your Morning Routine?"]]></title><description><![CDATA[
<p>I'm also on team Keep An Eye On Things™, and approximately none of it really feeds into an anxiety loop. (There's a tiny sliver of the pie that does, but it's easy enough to talk myself off that ledge and go engage in a Weltschmerzspaziergang[0].)<p>I know it's stuff I can't control, and that's sort of the point. I want to know what I can't control so that I can know what I <i>can</i> control, if that makes sense.<p>0: Otherwise known as "touching grass."</p>
]]></description><pubDate>Thu, 02 Jan 2025 18:56:49 +0000</pubDate><link>https://news.ycombinator.com/item?id=42577482</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42577482</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42577482</guid></item><item><title><![CDATA[New comment by nrr in "Database mocks are not worth it"]]></title><description><![CDATA[
<p>> There's something very, very wrong in the way we write programs nowadays.<p>I largely agree, but...<p>> ...  the database is you main source of invariants.<p>I guess my upbringing through strict typing discipline leaves me questioning this in particular. I'm able to encode these things in my types without consulting my database at build time and statically verify that my data are as they should be as they traverse my system with not really any extra ceremony.<p>Encoding that in the database is nice (and necessary), but in the interest of limiting network round-trips (particularly in our cloud-oriented world), I really would prefer that my app can get its act together first before crossing the machine boundary.</p>
]]></description><pubDate>Tue, 31 Dec 2024 16:53:33 +0000</pubDate><link>https://news.ycombinator.com/item?id=42559919</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42559919</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42559919</guid></item><item><title><![CDATA[New comment by nrr in "Database mocks are not worth it"]]></title><description><![CDATA[
<p>> If your unit tests have some overlap on your integration tests, that's nbd especially seeing as you can run your unit tests in parallel.<p>Exactly.<p>Another upside I've run into while doing things this way is that it gets me out of being relational database-brained. Sometimes, you really do not need the full-blown relational data model when a big blob of JSON will work just fine.</p>
]]></description><pubDate>Mon, 30 Dec 2024 23:40:15 +0000</pubDate><link>https://news.ycombinator.com/item?id=42554852</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42554852</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42554852</guid></item><item><title><![CDATA[New comment by nrr in "Database mocks are not worth it"]]></title><description><![CDATA[
<p>> The only thing enforcing these invariants in production is the interplay between your database schema and the queries you execute against it."<p>I'm unsure that I agree. The two examples you gave, establishing that IDs are unique and that updates to entities in the system are serializable (and linearizable while we're here), are plenty doable without having to touch the real database. (In fact, as far as the former is concerned, this dual approach to testing is what made me adopt having a wholly separate "service"[0] in my applications for doling out IDs to things. I used to work in a big Kafka shop that you've almost certainly heard of, and they taught me how to deal with the latter.)<p>That said, I'd never advocate for just relying on one approach over the other. Do both. Absolutely do both.<p>> I'm pretty sure "don't repeat yourself" thinking has led to the vast majority of the bad ideas I've seen so far in my career. It's a truly crippling brainworm, and I wish computer schools wouldn't teach it.<p>I brought up WET mostly to comment that, if there's one place in software development where copying and pasting is to be encouraged, testing is it. I'd like to shelve the WET vs. DRY debate as firmly out of scope for this thread if that's alright.<p>0: It's a service inasmuch as an instance of a class implementing an interface can be a service, but it opens up the possibility of more easily refactoring to cross over into running against multiple databases later.</p>
]]></description><pubDate>Mon, 30 Dec 2024 23:12:02 +0000</pubDate><link>https://news.ycombinator.com/item?id=42554674</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42554674</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42554674</guid></item><item><title><![CDATA[New comment by nrr in "Database mocks are not worth it"]]></title><description><![CDATA[
<p>I think it's probably worth mentioning that the principal concern for tests should be proving out the application's logic, and unless you're really leaning on your database to be, e.g., a source of type and invariant enforcement for your data, any sort of database-specific testing can be deferred to integration and UAT.<p>I use both the mocked and real database approaches illustrated here because they ultimately focus on different things: the mocked approach validates that the model is internally consistent with itself, and the real database approach validates that the same model is externally consistent with the real world.<p>It may seem like a duplication of effort to do that, but tests are where you really should Write Everything Twice in a world where it's expected that you Don't Repeat Yourself.</p>
]]></description><pubDate>Mon, 30 Dec 2024 22:11:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=42554102</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42554102</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42554102</guid></item><item><title><![CDATA[New comment by nrr in "Starlark Programming Language"]]></title><description><![CDATA[
<p>Starlark is Turing-incomplete, which makes it somewhat unique among embeddable languages. It's definitely a draw for me for something I'm working on.</p>
]]></description><pubDate>Mon, 09 Dec 2024 15:49:01 +0000</pubDate><link>https://news.ycombinator.com/item?id=42367305</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=42367305</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=42367305</guid></item><item><title><![CDATA[New comment by nrr in "How to Lead Your Team When the House Is on Fire"]]></title><description><![CDATA[
<p>It was! I've, however, gotten way more use out of saddling whoever is most senior with the role of making sure the team as a whole is on track. This way, it's a little more familiar with the way Western management hierarchy operates without turning it too much on its head. It's something of a leadership billet without removing the ability to be technical, which is important for a lot of folks.<p>It tends to work pretty well in an environment that both lacks a bug tracker (so that individual people aren't assigned things) and has a culture of pairing or mobbing.</p>
]]></description><pubDate>Mon, 16 Sep 2024 00:51:03 +0000</pubDate><link>https://news.ycombinator.com/item?id=41551746</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41551746</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41551746</guid></item><item><title><![CDATA[New comment by nrr in "How to Lead Your Team When the House Is on Fire"]]></title><description><![CDATA[
<p>I'll push back in defense of Scrum, but it probably bears a little explanation because my conceptualization of that framework is very likely a lot different from yours. (As something of a bonus: I'll bring in the military given the whole "wartime" trope.)<p>In particular, Scrum is only there to establish rituals that enable empiricism in decision making. A sprint is a reporting period to keep the team from spending too much time in the weeds. A standup is there to keep the team working together. The andon cord (which is often missing I find) is there when the facts have changed so utterly profoundly that everyone needs to regroup.<p>Anyone who's been through RTC ("boot camp"), and even some who haven't but have lived vicariously through others, understand that being constantly yelled at by RDCs ("drill instructors") on how you make your racks and fold your clothes is all about building certain habits and only tenuously related to what you'll be doing after A-school. It all has more to do with building trust that the rest of the folks in your ship will help carry you when the going gets tough. Scrum, at its core, is kinda like that.<p>I really dislike the term "Scrum Master." They're a team captain. The more military-minded might be keener to use "gunnery sergeant" or "chief petty officer:" they're just the most senior person in the rating group^W^W^W^Won the team. (Though, I'd probably take more inspiration from the Marines than the Navy here: a culture of servant leadership seems to bring out the best in people.)<p>The most popular implementations of Scrum tend to come with a ridiculous amount of meeting and tool baggage, and it's so unnecessary.<p>Use Excel. Hold your standups at the close of the day so people can go home. Write your product backlog items in delivery order so that sprint planning is less about sitting in one room playing poker and more about just getting valuable shit done.<p>That said, what isn't unnecessary, however, is kneecapping command a little: the engineering officer of the watch has comparatively little understanding of the actual operation of the machine. They just know that they want operational excellence. However, that excellence also sometimes comes with the watch supervisor—a subordinate—publicly calling out mistakes that the watch officer makes.</p>
]]></description><pubDate>Sun, 15 Sep 2024 23:23:24 +0000</pubDate><link>https://news.ycombinator.com/item?id=41551326</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41551326</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41551326</guid></item><item><title><![CDATA[New comment by nrr in "i3wm inspired wm for Windows"]]></title><description><![CDATA[
<p>cmd.exe is largely still concerned with starting processes and hooking them together in much the same vein as Bourne shell, so I tend to use it for that.<p>(I actually use Yori[0], but it's pretty much to tcsh what cmd.exe is to csh.)<p>PowerShell leaned a little too hard into the structured data to be useful for me as a command shell. It's a pretty decent competitor to the Python REPL though.<p>0: <a href="https://github.com/malxau/yori">https://github.com/malxau/yori</a></p>
]]></description><pubDate>Sun, 15 Sep 2024 20:38:04 +0000</pubDate><link>https://news.ycombinator.com/item?id=41550179</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41550179</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41550179</guid></item><item><title><![CDATA[New comment by nrr in "We've Got Depression All Wrong. It's Trying to Save Us"]]></title><description><![CDATA[
<p>"A depressed person often wants to be depressed ..." I'd caution against expressing it this way. It's less a want and more a <i>ground state</i>.<p>I am one of these depressives, and I definitely do not <i>want</i> to spend all day in bed. It is, however, a ground state that takes an amazing amount of energy to escape, so my usual inclination is to conserve energy and not escape. It may outwardly look to non-depressives as a strong desire to spend the day in bed and away from the world except through whatever portal the Internet gives us, but it's my experience that having someone to come by to help with the parts of living that fatigue me is direly, overwhelmingly underrated.<p>And, like, it isn't often chores or errands that are the most helpful. (Indeed, when my depression saps me enough, I find that just going on a cleaning binge is a cheap way to recover for a while.) No, rather, it's stupid shit like having someone make decisions for me so that I can get un-stuck from whatever mental hell I've fallen into. The challenge is usually articulating which decisions I need made because merely unpacking them has a high energy cost.<p>It's only when I've gotten a handle on the fatigue each day that I'm truly able to get moving.</p>
]]></description><pubDate>Mon, 02 Sep 2024 00:22:46 +0000</pubDate><link>https://news.ycombinator.com/item?id=41421450</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41421450</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41421450</guid></item><item><title><![CDATA[New comment by nrr in "Using Fibonacci numbers to convert from miles to kilometers and vice versa"]]></title><description><![CDATA[
<p>In practice, at least in my experience, only up to 13. (Though, I have the sequence memorized up to 21 because of a sign outside Chattanooga[0], which is what gave me my "hey, wait" moment about this.)<p>A combination of both the fundamental theorem of algebra and Zeckendorf's theorem has allowed me to fill in the rest so far. For example, 25 mi = 5 * 5 mi, which yields 5 * 8 km = 40 km. As it turns out, that is how far Cleveland, TN, lies from Chattanooga.<p>0: <a href="https://usma.org/metric-signs/tennessee" rel="nofollow">https://usma.org/metric-signs/tennessee</a></p>
]]></description><pubDate>Fri, 30 Aug 2024 20:26:05 +0000</pubDate><link>https://news.ycombinator.com/item?id=41404121</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41404121</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41404121</guid></item><item><title><![CDATA[New comment by nrr in "Faster CRDTs (2021)"]]></title><description><![CDATA[
<p>Fossil (<a href="https://fossil-scm.org" rel="nofollow">https://fossil-scm.org</a>) is actually a proper grow-only set from what I can tell: merge conflicts upon synchronization are encoded in the DAG as forks of the history at the conflicting points in time. If no action is taken after a fork, all clones will eventually see the exact same view of the history.<p>The tooling will normally bail with a "would fork" message if a `fossil update` (and, hence, local resolution of those conflicts) wasn't undertaken before pushing, but this is not at all necessary to preserve useful operation.</p>
]]></description><pubDate>Tue, 27 Aug 2024 23:49:59 +0000</pubDate><link>https://news.ycombinator.com/item?id=41374532</link><dc:creator>nrr</dc:creator><comments>https://news.ycombinator.com/item?id=41374532</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=41374532</guid></item></channel></rss>