I could use some honest advice from experienced programmers and engineers.
I'm almost at the two year mark as a developer. On paper I might look like a passable Junior Dev, but if you sat me down and asked me about algorithms or anything else I did to get my job in the first place I would be clueless. I can solve problems and always get my work done, but I don't even know the language/framework I use daily well enough to explain what's going on, I can just do things. I don't think I have imposter syndrome, I think I really might have let any skill I had atrophy.
I used to enjoy programming as a hobby in my spare time, but in two years I've opened the IDE on my personal machine no more than twice. People talk about all the side projects they have, but I have none. I feel too stressed out from the job to do any programming outside of work, even though I love it. I feel like I can't level up from a Junior to Senior because I either don't have the headspace or the will to do so. It doesn't help that the job I've had has taught me very little and my dev team has been a shitshow from the beginning.
At the moment I have an offer on the table to do a job that isn't engineering (but still tech) and it surprisingly pays more. Part of me thinks I should take that job, rediscover my passion in my spare time and build my skills, but I fear I might go down this route and never be able to come back to engineering. Not that I'm sure I want to.
It might sound defeatist but I don't think I'll ever be a top 5% or even 25% engineer. I could be average with a lot of work, but not great. I could potentially be great in the new field I'm being recruited for, but that's also hard to say without being in the job.
I know that some people just aren't cut out for being engineers. Maybe I have the aptitude but not the mentality to do this for 30+ years. I want to know if that's what it sounds like to people who've seen that before. If you were in my position, would you walk away and just be a hobbyist programmer or stick it out and hope to be a mediocre engineer one day?
I could use some honest advice from experienced programmers and engineers.
Old person programmer checking in.
if you sat me down and asked me about algorithms or anything else I did to get my job in the first place I would be clueless.
Don't sweat it. No one knows how the fuck computers work.
Anyone who thinks they actually know, isnt educated enough to understand about the bits they don't understand.
I can solve problems and always get my work done, but I don't even know the language/framework I use daily well enough to explain what's going on, I can just do things.
Nice. You've got the important part. Ride that until the end.
I don't think I have imposter syndrome, I think I really might have let any skill I had atrophy.
It's not impostor syndrome when you're only 2 years into your career.
If you feel like you don't know jack shit compared to what I know, after decades... that's because you don't know jack shit compared to what I know. There's nothing wrong with that. Someday I'll be pissing myself in a nursing home run by automation you maintain. We all get our turn.
I'm the meantime, lucky for you, I can't be arsed to work more than 40 hours in a week, so there's plenty of work left to do while you learn.
And I'll retire soon, and I'l promise I'll do you a solid and leave decades of my own mistakes and missteps out there for you to earn $$$$ cleaning up after. You're welcome... I guess.
I used to enjoy programming as a hobby in my spare time, but in two years I've opened the IDE on my personal machine no more than twice.
This is very normal. Welcome to the big leagues. If you do something you love for your job, eventually it's still just a job.
People talk about all the side projects they have, but I have none. I feel too stressed out from the job to do any programming outside of work, even though I love it.
This is very normal for your current stage of your career.
If you stick with it, it gets better when you get to someday become a self-important slob like me who only works on really interesting problems.
And how do I only work on really interesting problems? I make my boss hire a few junior developers and I delegate all the boring stuff to them.
It's a pretty sweet deal for at least one of us. (Who for, varies by the day, really.)
I feel like I can't level up from a Junior to Senior because I either don't have the headspace or the will to do so.
I guarantee that you've learned way more than you think. If you stick with it, you'll have a random moment sometime soon when someone else just can't wrap their head around a concept you take for granted.
It doesn't help that the job I've had has taught me very little and my dev team has been a shitshow from the beginning.
That sucks, sorry. There are more shitty developer teams than good ones. If you stick with it, and do some strategic job hopping, you can find the good ones.
This is a tough time to switch jobs in tech, I wouldn't blame you for not wanting to mess with it.
At the moment I have an offer on the table to do a job that isn't engineering (but still tech) and it surprisingly pays more.
Hell yes! Fuck your current employer for underpaying you!
And you already admitted your current team is shit.
Go take that money!
but I fear I might go down this route and never be able to come back to engineering. Not that I'm sure I want to.
Your developer skills won't vanish. Trust your future self.
If someone asks why you spent time as a non-developer "those assholes weren't paying a fair wage" is a fine answer.
It might sound defeatist but I don't think I'll ever be a top 5% or even 25% engineer.
As a top 5% engineer (with a trophy for humility), it's not all they promised.
It turns out there's still plenty I don't know, and I spend much more of my time confused and frustrated than I did before. The cool part is that I'm now confused and frustrated by really interesting problems.
I could be average with a lot of work, but not great.
I pay top dollar for average programmers. I'm not hiring right now, but let's stay in touch.
There's a lot of coders out there without the self awareness to realize what they don't know. Those programmers never get any better, and never reach average.
(Contrasted with myself, who, as I said, have several awards for excessive humility in spite of my undeniable genius. /s)
I could potentially be great in the new field I'm being recruited for, but that's also hard to say without being in the job.
Go find out!
Beware though, when they find out you can code, they will find a way to add that to your job duties.
I know that some people just aren't cut out for being engineers.
True. Some people's ego or laziness blinds them to what they need to learn.
I have a huge ego, and I am deeply lazy, but I occasionally put both in check for just long enough to learn.
Maybe I have the aptitude but not the mentality to do this for 30+ years.
Take it a year at a time. Once in awhile, take out some cash and spread it on the ground and sort of roll in it.
Hopefully you've noticed, but while this job is usually a pain in the ass, it also pays really fucking well.
I want to know if that's what it sounds like to people who've seen that before.
I've had this conversation with all of my very top people, if that's any consolation.
If you were in my position, would you walk away and just be a hobbyist programmer or stick it out and hope to be a mediocre engineer one day?
If you told my younger self how much money I could make as a mediocre engineer, I would be all over that deal.
I would've agonized about the trade-off if I knew I would stop loving my hobby, but taken comfort that I would later love it again.
Everything happens in seasons. Some seasons I code for fun. Some I don't.
A cool side effect of being paid to code is that when I do find the mind space to hobby code, I am a fucking badass hobby coder.
I think you should take this job because your current employer is running a shitty team, and underpaying you. Then take another programming job later when the next opportunity arrives (and it will..it really will.)
It turns out there's still plenty I don't know, and I spend much more of my time confused and frustrated than I did before. The cool part is that I'm now confused and frustrated by really interesting problems.
This is spot on. Your whole response ist just a trove of insight, I wouldn't have been able to articulate so eloquently.
Not to hijack from the OP, but would you change your reply if someone was feeling similarly but wasn’t yet in their first role yet? I’m coming out of 2 years of private mentorship and have spent the last almost 3 months applying with barely a whisper of a reply from a fraction of these jobs so I’m a bit down on myself. I felt confident a month ago but now I’m slinking back applying to jobs in my old industry.
Once you're in the industry and see the typical shitshow that goes on in most companies and teams, you won't think twice about not hearing anything for 3 months. There's a million reasons why you won't get a job or not hear back for a really long time that have nothing to do with you. Stick with it, times are tough right now but your luck will eventually change.
I saw a 20 year veteran programmer have a 3 month job search last year. I haven't seen that since Y2K. Both in Y2K and the 2008 recessions, it was tough to break into the industry.
Are you guys both my colleagues? This feels so unbelievably relatable. Seems like a universal issue with junior devs. OP, hang in there if you want to, or don't if you don't want to. Your journey seems normal to me :)
Oof. Imposter syndrome is real and it's debilitating. If a person does their job to the best of their ability and stops giving a fuck about what others might think, it becomes easier to overcome.
OP needs to realize that engineering is not about memorizing algorithms or being in the top 5%. It's about doing whatever work you are paid to do efficiently and quickly. Quite honestly, most "engineers" I know don't even do that much.
Monday through Friday/8-5, engineering is about solving stupid problems and getting a paid for it. That's it. (Maybe you have to go to meetings too.)
Some engineers can memorize formulas and rattle off 200 ways to do a thing. Some engineers are constantly in some kind of dick-swinging contest with their peers. Some are constantly chasing the "new shiny" and won't shut the fuck up about it. The most annoying ones blast out "helpful code segments" on LinkedIn to make themselves look smarter.
Fuck all that noise. It's annoying, a distraction and it'll cause a person to get burned out of the field super quick.
Sorry if that was a bit of a rant, but I have seen too many bright eyed Jr. engineers get crushed by the bullshit that can go on.
Don't confuse a bad work environment with not liking or being suitable for your job.
If you liked programming, do your work in the way that made you originally liked programming. People will put pressure on you to just "do things". Don't. Ensure you start understanding, slowly get more insight into what's going on. Ask the people around you any and all questions you need to get more understanding. Allow yourself to learn. That is the only way to start feeling in control, and the only way to become 'more senior'.
That being said. If you want to move on, there's no harm, and no shame. Just do it because you'll be doing something you know you will like better.
Hobby dev with a different main profession for 20 yrs here. Its the same everywhere, in any profession. I know, I‘ve had a couple.
In a bad environment, you‘ll never flourish. You wont even know your actual strengths. Please quit, try something else. Not necessarily a different profession but definitely a different team/company.
Most of what you mentioned tells me that you‘re currently in a bad place. If the team is bad, everything else gets spoiled. Sadly, you need experience to tell the difference. It might be great for someone else even, just not for you.
What you could use is some hard evidence to your strengths, your passions and your specific personality. Most likely this is achieved by taking a break. Either a long nice vacation or moving on. But time off is very important. Reflection is the key and it needs time and space.
All the best and dont worry about not being enough or doing badly. You‘re doing allright.
Some people are passionate about their jobs and some people just do it as a means to an end. There is nothing wrong with being in the later group and I say that as someone with ~20 years in the software space and never opens an ide at home.
I've always thought the best way to kill a hobby was to turn it into a job. I won't speak to if you should or shouldn't change roles, there are a huge amount of factors to consider there, I'll just say that not everyone who is successful in development is a guru, ninja, in it for the love, kind of person.
I've always thought the best way to kill a hobby was to turn it into a job.
100%
I tried turning my hobby of programming into my job. On the surface, I was reasonably successful, but the most enjoyable aspects of my hobby had to be set aside in favour of actual productivity.
Worse, the fact that I actually got pleasure from my work left me open to exploitation. When I finally woke up to that, I ditched programming in favour of "just a job" that paid the bills and was about a million times happier as a result. It's only recently, 15 years after leaving the field, that I find myself once again drawn back to programming.
I say take the job that pays more and rediscovery your joy. The world needs more people who understand how to code but do something other than code as their full time job.
I am called a srnior developer and I haven't done a project in my spare time in many years. Not because I don't want to, but because I do enough of that at work and I lack the energy. Most people I know are in the same boat.
I can solve problems and always get my work done, but I don't even know the language/framework I use daily well enough to explain what's going on, I can just do things.
Solving problems and getting a result that someone else is happy with is 90% of engineering. No one knows everything, your job is to use what you DO know to figure something new out.
The last 10% is what you need to work on - being able to confidently explain to a boss what you do in way that they understand while sounding complex enough to justify your pay and subsequent raises.
In time you will learn whatever system your using.
However, on the flip side, if the current job isn't getting you anywhere and everyone there sucks. Leave, take the better paying job for a little while, continue working on your skills and look for a engineering job elsewhere.
It seems like you are stuck in a bad environment at the moment and that does not help with your own progression.
Having a good team culture makes a lot of difference. When you get support and help from your lead and other devs, it makes life a lot better, and you learn much more from one another.
Go. Go see what else is out there and find a better place for you.
100% this. If the job stresses you out so much you can't enjoy your time off then that's a toxic environment. If I think about work on the weekends or evenings it's because I'm excited about it.
I haven't used big 0 or algorithms in my 15 years of professional coding. It's just not important unless you work for a Google and even then you'd have support.
It's not just Google. If you enjoy that sort of thing there are industries where it's more important. Not every day. Not every team. And you'd have support like you say.
But you can go a lifetime without using it beyond rules of thumb.
Nothing you've said makes me feel like you should quit.
Wanting more money is a perfectly respectable reason to want to quit, and if you think it would make you happier, go for it. Get paid.
It's not better to be an engineer or anything. No one will mind or hold it against you if you come back and say that you were a jr dev, took a position as otherntech job, but it wasn't for you so now your back with a new perspective and set of experiences.
Programming was once my passion. I got a lot of joy from it. I still do, and I would say that it still is a passion. But I've stopped really doing side projects unless it's particularly interesting. There's more to life than career development, and that's okay.
Without seeing your code, I can't know how good you actually are. Like most people, you're probably average. Don't beat yourself up over not knowing algorithms. No one knows those, they know the keywords and how to describe a problem and then how to pick the right one or tweak something to make it right.
The road from jr to senior is also less about technical proficiency than you would expect.
Technical competency is a must, but you'll go further as a competent technical leader who can breakdown work, describe it, and help their teammates than as a lone high performer.
In my opinion you should take the opportunity and check if you will like this new job. And mind you in a lot of jobs there is room for some programming to automate some processes internally in the company if you feel like it.
But it is great that you acknowledge your weaknesses and accept them. I am also leading a team of sw devs and have a couple of juniors in my team and I try to dedicate enough time to them to explain to them more complex topics, give them recommendations on how to write better and more maintainable code, etc. And I have the feeling your lead isn't doing much or showing interest in your work, which is a pity and very demotivating because I have been in your shoes before and know exactly the feeling.
And a bit of perspective, I have a guy in my team who is pretty smart and overall a great Dev, the problem is that it is extremely difficult to work with him, he doesn't have a high working culture, thinks that others are stupid and doesn't do his job well. I know how much he can but it is really a pain to work with him. Believe me I tried a lot of different approaches with him to make it work and so far with mixed results.
On the other hand I have a junior in my team who isn't the best programmer and I believe he will never be, but he is very positive, works hard, really tries and in general has a very high work culture and it is so much more enjoyable to work with him, so you realise that skills and brain capacity aren't everything and that sometimes work attitude is way more important.
I wish you all the best in your new endeavour and I hope you feel happier soon.
You honestly sound like your stressed out and in fight/flight mode. The first step is just acknowledging where you are mentally and how it's going to make everything seem worse than it really is.
Over the 16 years since graduating, I learned that defining yourself by your career is often a trap. At least it doesn’t sound like you’re getting deep satisfaction from your work.
I burnt myself pretty bad going into the field thinking I was perusing a passion career and just kept getting kicked down for 5 years chasing a passion career until I found a work environment that paid decent and valued work/home life balance. In school I thought I’d never sell my soul, but now I’ve been working with the same people for a decade now and pretty happy about it, even with if the actual work is utterly boring.
Unless you’re a fortunate few that are truly passionate, driven, and lucky enough to land a career that fills your entire bucket, look for a job you can tolerate BUT with group of people that support you and your growth. In the end 2 years in is a drop in the bucket and you’ll see your career change directions over and over. You can always learn new skills or relearn them, so if this new job is something different to get you out of a slump, I say go for it. No one can answer for yourself but you.
Not a software engineer, but work closely with them in a different field. This is 100% common, especially for junior devs.
My honest advice is to push with it and truly spend some time in the field, and if you hate it, then leave without regrets. However, know that the initial bump is the hardest, over time it gets easier and you'll even likely find yourself doing side projects on your own time!
I took a 6 bootcamp, got a job straight away after as a full stack junior web developer.
Programming as a job was the single worst decision I make. I was working with languages and frameworks I don’t enjoy, I was building a product I don’t care about in the slightest.
It took me 1 year of full time web dev before I quit and went back to regular IT which isn’t the most fun thing, but it works for me. I’ve been doing it for over a decade so I can do it in my sleep, it’s easy money tbh. Programming for me is definitely more of a hobby than a job. Having it as a job really killed my love for it
Nowadays I only code in Python which I LOVE. I use my programming skills to automate work tasks, and I make small scripts here and there and it’s so much fun.
Solving small problems with scripts is just what I enjoy doing. I get to work on a project for a day or two. I can complete it fast then move on to something else.
Now I’m about transitioning into Data Engineering instead of Software Development.
Knowing nothing else about you or the new job offer, it makes sense to take the offer. But I'd rather know more than the information you've presented. The good news is that you do know more and can better determine if there are mitigating circumstances that make turning down the offer make more sense.
I used to enjoy programming as a hobby in my spare time, but in two years I’ve opened the IDE on my personal machine no more than twice.
This is why I have never taken on programming as a profession. I earn more than I would ever make as a developer (even a very senior developer) leveraging my (average) programming skills to produce a personal suite of software tools and scripts that means I can do my chosen profession better, faster and with less effort than any of my colleagues or competitors. I have also developed small apps on a private/ personal basis that I have then sold to my employer for wider use in the company.
And I still enjoy programming as a hobby as much as I ever have. Don't underestimate how much being able to program at even an average level can boost a career in another field.
Tldr; take offer, don't quit engineering yet, you are fine
Don't quit engineering if you enjoy it. If you have better offer and the current ship is leaky as fuck => jump the ship. Saving the leaky ships should be very profitable if it is not => you are being heavily exploited.
I jumped the ship thrice. And one time accepted a lower payed position, just because I was quite burnout.
On the topic not using the progress and not understanding the Intenals. Understanding internal will not make you senior. Understanding what you can apply that you already know can make you senior.
I remember being in a situation like yours. I thought I didn't know Jack, but then on a newplace I seen people who were running around like a headless chickens on crack. This has given me a good understanding about what knowledge is and that applicable knowledge is the key.
A couple of questions that may help you better understand your own potential;
Do you have any fun at work? And if so, is it due to the work or your colleagues?
Does your job keep you up at night? And if so, in a good or bad way (e.g. stressful)
Do you still have the feeling you could program as a hobby if you weren't stressed as balls?
Do you have any mentors/coaches/seniors that help you overcome times when you're stuck/don't know where to move?
Most engineers are in the bottom 80% btw, and a lot do valuable work (albeit slow, and not 'bugfree'). These people are generally most effective when supporting a senior that is in the top 10%.
Also the engineering market is currently pretty shit, and it's not looking to get better any time soon.
What ever choice you make, try to do something that 'energizes' you.
Mate Im writing this after reading the top half of your comment.
This is a normal path, and the insecurities are going to stay with you for a long time even after growing into sr
If you're not passionate that could be either in you or on your job, and the best way to see is if you search for other jobs and that excites you. So give yourself a chance and look what companies around you or far from you are doing.
As someone who switched from another domain to tech, I suggest trying to reason through your hesitation to switch away. Do you want to stay in tech because you like tech or because you're afraid of "giving up"?
In my other domain, I worked hard and did OK, but not stellar. In tech however, it's a completely different story. The other domain was "cool", and I don't regret what I learned along the way, but tech clearly comes easier to me compared to someone doing well in the other domain.
You need to be honest with yourself before you make the decision to switch. Are you running away from tech or towards something else?
I think there's some truth to being afraid to give up. But I can't see myself in any other industry, and I am proud of my work whenever I see it in production/being used irl. So that makes me think I'd always enjoy being involved with building stuff in some way.
In response to your last question, it might be both. I think my current job is a push factor, and the new field is a pull factor. As other commenters have rightly pointed out, I'm not enjoying my job. I don't know if that means it's wrong to recognise the signs that I might not be as motivated as I should be, though.
From your description, my view is limited, there is no correct solution. Any choice is viable and fine, and any decision you make will be due to the reasons you chose with.
You didn't disclose what the alternative opportunity and field is, and also not your view on the field and you in it. So it's difficult to assess and put into relation.
You didn't disclose what you did before work, but two years is not that much experience for an engineer. Especially if it is not a particularly nourishing environment. You gain such expertise through experience and exposure over time. Depending on the project and environment it's also not enough to fully understand and intuitively know a big project.
At my workplace we separate role from [personal] development level. As a developer one's role may be developer or lead developer. The development stages are Trainee, Junior, Professional, Senior. If you can work on tasks mostly self-reliant (asking and collaborating is still open of course; knowing when to ask is a skill too) and can put tasks and work into context, you are a Professional. A Senior can support and guide the team. It is perfectly fine to settle for Professional.
Not being exceptional is not a good reason to quit. If you work and bring value, that's still value. Don't decide whether you are valuable or good enough for others. (This leaves out the question of what it means for yourself of course. Tackle those questions individually.)
You say you get your work done. Continuing to do that at a Professional Developer rather than Senior level is fine. You still bring value.
I want to know if that’s what it sounds like to people who’ve seen that before. If you were in my position, would you walk away and just be a hobbyist programmer or stick it out and hope to be a mediocre engineer one day?
I really can't answer that specifically.
You said your team environment is not the best. I assume you don't do retrospectives or personal feedback. Is feedback something you could ask [of some of] your team members, lead, or seniors? (Take care not to poison your question for open feedback with your negative assumptions of yourself and your work.)
Where would youlike to be? Separating what you think is expected of you from your expectation and view of yourself and from what you enjoyed and where you think you would feel comfortable settling, how would you lay those out?
Have you considered switching project or employer? You have only seen and experienced that place. A different work environment could be very different - even in the same field.
Background: 16 years programming professionally, 20+ including hacking in high school. Currently in a principal engineer role.
Immediate reactions: you do not have to program in your free time. I ferment veges, I brew kombucha, I garden, I make hot sauce, I hike, I camp, I spend time with my dog, I game, I listen to music, I make music, I work on my house. I absolutely do not fucking program in my free time. I used to love programming, now it’s “what I do”, but I don’t love it.
That said, you may have to invest some of your free time to grow your skills. But your primary learning should be during your paid hours. If your job isn’t providing growth, that’s an issue with the company. There are better junior positions out there, but it is a guessing game. I do think it’s important to mention that the jump to senior is largely an accumulation of domain knowledge, not necessarily industry knowledge. Climbing the ladder is often a matter of sticking around long enough to get that promotion, then leveraging it into another company.
I wouldn’t blame you for taking the alternative job - and honestly, the best program managers, the best team leaders, have some experience doing the actual work. I’d say do it if it seems like a better opportunity. You can always circle back if you prefer the individual contributor route.
I do think it’s important to mention that the jump to senior is largely an accumulation of domain knowledge,
I feel that. I'm a senior dev on my team of about 7 software engineers, but I often feel like I'd just be a junior somewhere else. Worst case scenario is I can add to my resume that I helped convert a vb6 shop to a c# shop, not sure what that's worth though xD
I’m a manager at a FAANG and have been involved in tech and scientific research for commercial, governmental, and military applications for about 35 years now, and have been through a lot of different careers in the course of things.
First - and I really don’t want to come off like a dick here - you’re two years in. Some people take off, and others stay at the same level for a decade or more. I am the absolute last person to argue that we live in a meritocracy - it’s a combination of the luck of landing with the right group on the right projects - but there’s also something to be said about tenacity in making yourself heard or moving on. You can’t know a whole lot with two years of experience. When I hire someone, I expect to hold their hand for six months and gradually turn more responsibility over as they develop both their technical and personal/project skills.
That said, if you really hate it, it’s probably time to move on. If you’re looking to move into a PM style role, make sure that you have an idea of what that all involves, and make sure you know the career path - even if the current offer pays more, PMs in my experience cap out at a lower level for compensation than engineers. Getting a $10k bump might seem like you’re moving up, but a) it doesn’t sound like you’re comparing it to other engineering offers and b) we’re in a down market and I’d be hesitant to advise anyone to make a jump right now if their current position is secure. Historically speaking, I’m expecting demand to start to climb back to high levels in the next 1-2 years.
Honestly, it just sounds like your job sucks. I have regularly had students, interns, and mentees in my career because that’s important to me. One thing I regularly tell people is that if there’s something that they choose to read about rather than watching Netflix on a Saturday, that’s something they should be considering doing for a living. Obviously that doesn’t cover Harry Potter, but if you’re reading about ants or neural networks or Bayesian models or software design patterns, that’s a pretty good hint as to where you should be steering. If you’d rather work on space systems, or weapons, or games, or robots, or LLMs, or whatever - you can slide over with side and hobby projects. If you’re too depressed to even do that, take the other job. I’d rather hire a person who quit their job to drive for Uber while they worked on their own AI project than someone who was a full stack engineer at a startup that went under.
Anyway, that’s my advice. Let me know if I can clarify anything.
I personally work for more than 20 years as dev and really hate to see myself as senior. I think I am more of a Veteran. I only have more practice and survived more projects.
What I am trying to say is, give yourself time. Nobody starts out and knows everything.
And even if you have experience, there is always a bigger fish. Simply because the topics are too complex to know them all.
I used to be like you. I had passion for what I was doing. Then I got my first job.
Companies will suck your soul and your passion right out of you. Or sometimes you'll find a job where you can actually exercise your passion, but you'll have a shit boss that'll make you feel bad the whole time you're doing it.
It's really hard to find that one golden nugget of a job where your can do what you love and be treated right.
Having done this for about 25 years, I’ve noticed that conceptual knowledge and getting work done are very different things. Everyone, and I mean everyone, gets stuck when they’re developing. The people who become best at it are the ones that don’t get discouraged about getting stuck, and just keep banging away. Everything is getting more complex all the time. The people who claim to know it all are full of shit.
The real question is this: Do you wake up in the morning energized about solving that problem you went to bed stuck on? Or does it fill you with dread? If it’s the former, keep banging away. If it’s the latter, no job is worth sacrificing your health.
Being mediocre is fine. And you can't expect to feel competent after 2 years, especially if you're not in a supportive environment. Maybe 5 years. It took me muuuch longer than 5.... This stuff is hard, don't expect to master it quickly.
First of all if you solve problems that means you know enough of the subject to reason out the solution, it may not be perfect but very few solutions are.
I have been working on legacy code and maintaining old c++ code for a decade (200.000 loc) and most of the time I had to spend days debugging and reading code just to understand enough to get a possible solution, and then I still end up writing a solution that breaks in a different corner case that I never could have imagined.
So yes most of the time you feel like you don't know anything, but over time you end up knowing a lot of how that codebase works. And after two years you must have picked up something about what you are working on.
Then you have those programming language genius colleagues, that know all the tips and tricks of a language, I use them to get ideas on solutions, because they always have an opinion on what is the "right" way of doing stuff.
I also think it's probably a good idea to try out the new career path. Doing software dev as a job, and doing it as a hobby because you like to, are very different when it comes to motivations and goals. Don't think of it as walking away and just being a lowly hobby dev though, you can build your skills and work on what you want to as a hobby, for the problems you are trying to solve and things you like to work on, and that's totally ok.
Not everyone wants to put in the effort to play guitar for a living, but you can definitely still enjoy guitar.
As a senior engineer recently turned manager I hear this type of mentality from most of my junior all the way up to senior devs.
The only thing I'd suggest to you is spend some time digging into the tools you're building outside of the project you're working on. Just to get a general understanding of how the pieces fit together. Definitely do it during work hours, though. I'm in no way suggesting outside of work, here. Once you've spent enough time digging, you'll surprise yourself in how effective you get at answering questions.
I graduated college with a 2.8. I was a glorified HTML modifier for 2 years.
I've since job hopped, learned on the job, studied on my own, etc. and am a Principal Engineer making...a good chunk of money.
I am not book smart. I couldn't pass a Big Tech interview (probably). But there are plenty of jobs out there I can do and I can do well. For me it boils down to soft skills.
You have to do what's best for yourself and your situation.
I was a systems administrator for a decade or so and I reached a turning point... I had a bad experience, was burning out, and I had the opportunity to take a new sysadmin gig at a credit union, or take a step down to a support role, that paid more, with less responsibility, and had IPO shares...
My kid was getting ready for college, so option 1 positioned me well if I needed to load up student loans. Option 2 maybe made it so we wouldn't need student loans.
I went with option 2. Less stress, less responsibility, more pay, paid for kids college in cash, now through a series of IPOs and acquisitions, I'm working for a VERY large tech company.
Does "not being an engineer" look right for you? Quite possibly.
What you’re describing sounds like burnout to me. Stepping away from coding could be a good step in recovering. New offer certainly sounds worth trying, I hope it goes well.
Almost all what is going on today in commercial development is based on knowing frameworks and existing libraries and is far from engineering.
I am working in that 19 years and also feel that am not a true engineer, at least at my job. Yes, I developed my own UI client framework, but who know it, who need it except my company... I am not in the 5% of top world engineers. And you know what I think, I do not care. Do f#$*k off, commercial development. I have hobbies, I learn languages that I like and writing code just for fun, solving problems on codewars. I believe that true thech like C and freebsd, emacs and some other not popular in commercial development programming languages is my way. And yes, I am earning money at my job, but at the same time, as I said, I tell all these overhyped shit "do f#@&k off" and going my own way. That's my life. Have a luck, bro. Find your own path.
People like you should be in leadership positions. The landscape rewards quick solutions, and quick solutions are rarely good solutions. "Whatever works" might still be a bad solution, just look at electron and that entire ecosystem.