I could not wait for PDD (Poem Driven Development), where you have to write the unit tests / features as a poem... :D I mean in my time this was called as requirement specification and it was written in word it was readable for everyone but I guess that is now not fancy enough... However, really good explanation :)
Please continue. Unit testing is great but when it comes to business we developers need a common point to communicate with business language. Specflow is great for this. Thank you for nice introduction.
Excellent video for a starter like me on BDD, i will read the documentation and do a sample feature tonight. can you also make video talking about hooks ? it seems like Pre and Post steps during test run.
This plugin was only released last 28th of January if I remember correctly. I've wanted to learn using SpecFlow last year and there was no real support for Rider. Specflow support was both in the Jetbrains bugtracker as the Specflow github issues requested in 2017. The support for Rider related tools is growing, but sometimes it's just not there yet unfortunately. That said, I've been using Rider happily for a few years now.
This is a useful real-world example of BDD that kind of confirms my feeling about it, which is that it doesn't really add much. It takes a requirements spec and makes it into a harder-to-read format like gherkin and for what exactly? A requirements spec written in English is gonna be easier for a project manager to write (in fact every project manager I've met wants to do that instead of learning Gherkin) and perfectly easy for a team to analyze and implement. BDD seems to be solving a problem that doesn't exist.
Typical upper management attitude. Project managers generally want nothing to do with code or the responsibility of developing features, which is fine but now that an accountability factor exists that makes product directly responsible for the behaviour of the applicaiton and what is shipped its all "uhhh but we prefer plain english". Fuck off
Hey Nick, might be cooler if you mirrored your camera so that it looks like you're looking at the same code we're looking at when we're watching your videos 😊.
I'm programming for like 13 years, I also make some videos of programming but they are meant for the native romainian speakers because usually a part of them do not know that well English but man you really inspired me to give something back. To be honest you do an amazing job. Kudos ! Respect ! Anyway good job !
Romanian programmers do know English. Unlike other nationalities, we write the code in English, create the documentations in English, exchange emails in English, speak with the clients in English. We even borrowed terms from English to our vocabulary. Have you ever seen a Romanian using a Romanian keyboard :)) ? I believe only the people aged 50+ (with some exceptions, of course) don't know English, so maybe your content is more focused on them. Nick's doing a great job, indeed!
@@andreibicu5592 Dude, next time, ready my comment. There are people "THAT AREN'T PROGRAMMERS". "I also make some videos of programming but they are meant for the native romainian speakers because usually a part of them do not know that well English" ... Read that again slowly. " A PART OF THEM"
Nice subject. Please keep it up. It would be nice to build a more complex sistem as you progress so that we can see more realistic features. Including integration with local and external web apis. Maybe merge gRPC series with BDD to create a real world case at the end.
I had question about .feature.cs file and removed it when I solved it. But looks like you answered to my question Nick. Yes I tried to use [Binding] and it solved my issue. so Looks like with new updates we don't see anymore .feature.cs file but it works when we add [Binding] to our steps.cs class. Thanks
Looks interesting and I am interested to see more on this. but I imagine this being a nightmare practically. If business writes these features: 1. do they need access to source code or do devs copy paste it into the source? 2. Every time they write something that does not match what your code allows for it breaks the test. eg if they write "3 apples that cost 5 USD are added to the cart", do you have to tell them to use specific words and do a back and forth with them, or do you cater for different variations?
It's only harder to identify what went wrong with BDD if your Gherkin steps are not formulated correctly to be like something you would say to your domain experts. If something goes wrong, you only need to to stick a breakpoint before your scenario steps and verify that the steps are happening in accordance to the specs. But, yes, BDD does not mean you have to stop doing unit testing. If you feel like some classes need to be unit tested for tighter control, you can still do that.
From 4 years of writing SpecFlows : writing reusable Givens is the big challenge. If you do it the wrong way, you'll end up with thousands of Givens that are pretty much the same but not really, and then chosing one when you write a test is a nightmare... For example, I would advise against "Given a user that is logged in", because after you'll have "Given a user from that country", "Given a user that is 2m tall", 'Given a user that is right-handed". It's a nightmare, and scenario setup can become gigantic and unreadable. Instead, you can use an array to position all properties at once, and have only one Given per entity. That's what we did, it changed everyone's life !
One general question Nick. We are .Net or C# stack developer. Today I was reading new opening JD just for learning new technologies. I saw approximately 20 new opening. There were 12 to 13 jobs for Java developer and only 3 to 4 for .Net and C# developer and remaining for MEAN and MERN I did understand why ? even now Net core is open source and support multiple open source platform. Now my question is do we need to change our stack?
I can't know for sure but my personal take is this. Java has been around fo a long time and has been cross platform from the beginning making it more popular than C# and .NET. This means there is a ton of Java code that needs to be worked on and maintained. Companies can't easily turn an switch and convert their amazing Java developers to amazing .NET Core developers overnight. It's too expensive and too dangerous. So people that are using .NET Core/5 are in their overwelming majority, people who were already .NET Framework developers that knew C#. More and more teams and comapnies are picking up .NET 5 now but it's gonna be a long time before it becomes more popular than Java.
Agree with Nick 100%. NET Core is very fresh platform comparing to Java and many dotnet/c# shops are still having .NET Framework 4.7 or even 4.0 bases systems MVC, REST API, WebForms. Java is developing very dynamically while maintaining amazing backward compatibility with Java 8 or with previous releases. This allows Java teams to migrate projects more easily. For sure we should expect many legacy .NET Framework systems to be migrated soon, .NET Framework 4.8 is the last version of the framework and soon we should have .NET 6 LTS (good moment for the migration)
This is super interesting! Do you have any examples of authenticating by logging in an a wep page, then use cookies to authenticate and test towards a webapi?
Ah shoot I wanted to show how you can have matching on both it and they with the same attribute and I forgot! Basically you can add (it|they) or add a second attribute with different phrasing and they will both work. Can’t believe I forgot to show that
Depends on what you mean big scale. Do you mean throughput? Then sure I’ve seen it used in systems that do thousands of requests per second. Do you mind size of individual project code base? Probably but I only work with micro services so I wouldn’t know.
Gherkin has been around for a long time and is a universal syntax across any underlying language. It makes it really easy for product people to write no matter the technology that the team is using behind the scenes