Inspired by EdgeCase's fantastic Ruby koans, the goal of the F# koans is to teach you F# through testing.
When you first run the koans, you'll be presented with a runtime error and a stack trace indicating where the error occured. Your goal is to make the error go away. As you fix each error, you should learn something about the F# language and functional programming in general.
Your journey towards F# enlightenment starts in the AboutAsserts.fs file. These koans will be very simple, so don't overthink them! As you progress through more koans, more and more F# syntax will be introduced which will allow you to solve more complicated problems and use more advanced techniques.
The F# Koans currently target Visual Studio 2010. The koans should also work with Visual Studio 2015+, command line Mono, MonoDevelop, and Xamarin Studio.
NOTE: NuGet is required to properly resolve dependencies.
-
Open the Visual Studio project, right click on the "FSharpKoans" project in the solution explorer and select "Set as StartUp Project".
-
Turn off User-unhandled Exceptions. Go to Debug|Exceptions and uncheck the User-unhandled box from the Common Language Runtime Exceptions item.
You can now run the Koans by selecting Debug|Start Debugging (defaults to f5).
The following instructions will run the Koans without the need for Visual Studio, MonoDevelop, etc. The only requirements are Mono, FSharp, and NuGet.
-
In a terminal, navigate to the root of the FSharpKoans solution directory.
-
Restore all NuGet packages (replace /Path/To/NuGet with the appropriate directory for your environment):
mono /Path/To/NuGet/nuget.exe restore FSharpKoans.sln
-
Build the solution:
msbuild FSharpKoans.sln
You can now run the Koans (the following assumes your output path is bin/Debug):
mono FSharpKoans/bin/Debug/FSharpKoans.exe