• kryptonianCodeMonkey@lemmy.world
    link
    fedilink
    arrow-up
    73
    ·
    edit-2
    9 days ago

    As a data engineer, testing with production loads is critical to performance checking, as well as finding edge cases where your assumptions about what can be expected in the data are curb stomped and send you back to the drawing board to cry and think about what you’ve done.

    • jjjalljs@ttrpg.network
      link
      fedilink
      arrow-up
      38
      ·
      9 days ago

      Yeah we finally set up a workflow where we get production data available in a staging environment. This has saved a lot of trouble via “well it worked on my local where there were 100 records, but prod has 1037492 and it does not”

      • kryptonianCodeMonkey@lemmy.world
        link
        fedilink
        arrow-up
        19
        ·
        9 days ago

        Same. Early on as a new dev, I failed to performance check my script (as did my qa tester) before it was released to production, and that was my first roll back ever. It was very unoptimized and incredibly slow under one of our highest density data streams. Felt like an idiot that I was good with it’s 1-2 second execution time in the dev environment.

        • 🐍🩶🐢@lemmy.world
          link
          fedilink
          English
          arrow-up
          4
          ·
          9 days ago

          I deal with this constantly. Profilers are your friend. I keep begging my team to use the database dumps from production to test with, but nope. Don’t feel bad about messing up though. The amount of fuck ups I deal with in prod is exasperating. At least most of the things I break is a quick 5 minute fix and not weeks of rework.

          The hardest thing I have explaining to the team is the concept of time. Once you have done controls programming and get to witness how much happens in 50-100ms, it sinks in. Your thing takes 500ms? 1 second? They think this is acceptable on something that is dealing with less than 100 database records. 😭

      • _stranger_@lemmy.world
        link
        fedilink
        arrow-up
        3
        ·
        edit-2
        8 days ago

        I once tanked a production service by assuming it could handle at least as much load as my laptop on residential sub-gigabit Internet could produce.

        I was wrong by at least an order of magnitude.

    • Crashumbc@lemmy.world
      link
      fedilink
      English
      arrow-up
      17
      ·
      9 days ago

      17 years working with hospital patient data. I’m going to curl up in a corner and cry now…

      • Skullgrid@lemmy.world
        link
        fedilink
        arrow-up
        21
        ·
        9 days ago

        dev teams usually :

        What’s the worst that could happen,people won’t die

        this guy :

        17 years working with hospital patient data

        must be high pressure work.

    • ivanovsky@lemm.ee
      link
      fedilink
      arrow-up
      9
      ·
      9 days ago

      And then managers that don’t get this will try to shove policies down our throats about how “pre-prod systems should not have access to prod data”.

      “just obfuscate it.” Sure, for all 300Tb of it from the 10 different sources that don’t really talk to each other and we were already doing magic to be able to join them together? They should give us a bottle of hard liquor per month/project.

      • ℍ𝕂-𝟞𝟝@sopuli.xyz
        link
        fedilink
        English
        arrow-up
        5
        ·
        8 days ago

        As one of the devops/sysadmin types, if we give access to prod data to preprod systems, they are now in audit scope and you have to harden them or we lose our insurance and compliance certs.

        Obviously the solution is to build some system where everything works out, but it’s not as easy as “just give root to devs”.

        • wizardbeard@lemmy.dbzer0.com
          link
          fedilink
          English
          arrow-up
          3
          ·
          edit-2
          8 days ago

          Yup. Regulatory and audit requirements are a motherfucker.

          Also, I don’t mean to speak down to devs, but as a rule of thumb you tend to think far higher of your skills just because you know the building blocks. Being able to build a boat doesn’t mean you know how to sail.

          I know multiple people who are prodigous developers but know jack shit about basic computer usage and security. People who had to be guided to the control panel in Windows. Yes, even after they added the search bar. People hired to work in an exclusively Windows enterprise environment.

          Now add that amount of potential that lack of basic operational skill carries for fucking things up to the least competent (or at minimum the least careful) co-worker on your dev team.

          You (any dev reading this) as an individual would probably never fuck up that badly. You (any dev reading this) would probably do everything right, correct, and wouldn’t cause problems with root. But the rules aren’t written to protect against the competent, or against people never making mistakes.

      • kryptonianCodeMonkey@lemmy.world
        link
        fedilink
        arrow-up
        3
        ·
        edit-2
        9 days ago

        I test my own code/scripts in dev when I’m working on it. QA usually tests acceptance criteria in test environment. And then staging is used for production data testing for performance and identifying missed edge cases. Actually, we sometimes use dev and test interchangeably when multiple people are working on the same repo, so the lines are a little blurrier than that.

    • _stranger_@lemmy.world
      link
      fedilink
      arrow-up
      3
      ·
      8 days ago

      A coworker once got an HR talking-to for printing this meme out and leaving it on all the dev’s desks.

      • dev_null@lemmy.ml
        link
        fedilink
        arrow-up
        9
        ·
        edit-2
        8 days ago

        Regardless of the meme, it’s just weird behaviour to print off a meme, in presumably tens of copies, and leave it on every desk. Don’t you have a group chat?

  • stupidcasey@lemmy.world
    link
    fedilink
    arrow-up
    13
    ·
    9 days ago

    I have three setups DEV: an environment that is almost useless thanks to how many changes have to be made between production and the development environment.

    TEST: A More useful exact cloan of production that you still have to edit specific things but it is usually the same each time.

    PROD: this one just never works right.

  • corsicanguppy@lemmy.ca
    link
    fedilink
    English
    arrow-up
    13
    ·
    9 days ago

    “as above, so below”

    If your test and prod are different, you need to ensure your manager understands the risks you will not magically account for. It’s on their head when it fucks up.

    Testing in prod requires its own separate indemnification because that’s also only ever after direct orders.

  • marlowe221@lemmy.world
    link
    fedilink
    English
    arrow-up
    12
    ·
    9 days ago

    I’ve definitely had the experience of something being broken in Prod… and no one can reproduce it in Dev.

    Guess where we are fixing it!?

    • ℍ𝕂-𝟞𝟝@sopuli.xyz
      link
      fedilink
      English
      arrow-up
      7
      ·
      8 days ago

      Reminds me of this old aeronautical joke. Context is a plane maintenance log.

      Plane grounded, airspeed indicator inaccurate above 500 kts. (Signature of the pilot)

      Plane airworthy, could not reproduce issue on the ground. (Signature of mechanic)

  • collapse_already@lemmy.ml
    link
    fedilink
    English
    arrow-up
    6
    ·
    8 days ago

    Test only on dev hardware because production hardware is too expensive to waste on developers. No idea why the software runs better on dev hardware than production. They’re kind of similar.

  • Spacehooks@reddthat.com
    link
    fedilink
    English
    arrow-up
    4
    ·
    8 days ago

    Yall don’t use the consumers as the test. It saves 60% of upfront costs!

    Remember to buy “Aunty’s Cleo It’s Better than nature!”