Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/SaturnFramework/Saturn
Opinionated, web development framework for F# which implements the server-side, functional MVC pattern
https://github.com/SaturnFramework/Saturn
backend cross-platform fsharp mvc mvc-architecture mvc-framework saturn server-side server-side-rendering web
Last synced: 3 months ago
JSON representation
Opinionated, web development framework for F# which implements the server-side, functional MVC pattern
- Host: GitHub
- URL: https://github.com/SaturnFramework/Saturn
- Owner: SaturnFramework
- License: mit
- Created: 2017-12-23T23:36:30.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2024-07-31T12:04:48.000Z (6 months ago)
- Last Synced: 2024-10-20T01:56:07.941Z (3 months ago)
- Topics: backend, cross-platform, fsharp, mvc, mvc-architecture, mvc-framework, saturn, server-side, server-side-rendering, web
- Language: F#
- Homepage: https://saturnframework.org
- Size: 5.08 MB
- Stars: 714
- Watchers: 28
- Forks: 109
- Open Issues: 51
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Saturn
![Build](https://github.com/SaturnFramework/Saturn/workflows/Build/badge.svg) ![GitHub last commit](https://img.shields.io/github/last-commit/SaturnFramework/Saturn?style=flat-square) ![Nuget (with prereleases)](https://img.shields.io/nuget/vpre/Saturn?style=flat-square)
[![Open in Gitpod](https://gitpod.io/button/open-in-gitpod.svg)](https://gitpod.io/#https://github.com/SaturnFramework/Saturn)
Saturn is a web development framework written in F# which implements the server-side MVC pattern. Many of its components and concepts will seem familiar to anyone with experience in other web frameworks like Ruby on Rails or Python’s Django.
It's heavily inspired by Elixir's [Phoenix](http://phoenixframework.org/).
Read more about why I've decided to create Saturn, and some of its design choices on my blog - http://kcieslak.io/Reinventing-MVC-for-web-programming-with-F
## Documentation
Saturn has nice [documentation](https://saturnframework.org/explanations/overview.html) and I appreciate any help to improve it further by sending pull requests or just adding an issue with what you think is missing.
## How to build
1. Install the .NET 6.0 SDK from https://dotnet.microsoft.com/download/dotnet-core/6.0
2. Restore dotnet SDK tools: `dotnet tool restore`
3. Inside the repo directory, run `dotnet run`## How to run the automated tests for this project
Here we will present two ways of running the automated tests for this project. The first one is the preferred way since it is the same command used in the [CI build script](https://github.com/SaturnFramework/Saturn/blob/main/.github/workflows/build.yml#L23):
* Inside the repo directory, run `dotnet run -- Test`.
Although, there is this second approach where you can specify a test scenario to run filtering by its statement:
1. Change the directory to the tests folder using `cd tests/Saturn.UnitTests/`
2. List all the tests statements with this command: `dotnet run --list-tests`
3. Run only one test scenario, filtering by the test statement like in this example: `dotnet run --filter "Controller Routing Tests.Add works"`.## How to contribute
*Imposter syndrome disclaimer*: I want your help. No really, I do.
There might be a little voice inside that tells you you're not ready; that you need to do one more tutorial, or learn another framework, or write a few more blog posts before you can help me with this project.
I assure you, that's not the case.
This project has some clear Contribution Guidelines and expectations that you can [read here](https://github.com/SaturnFramework/Saturn/blob/main/CONTRIBUTING.md).
The contribution guidelines outline the process that you'll need to follow to get a patch merged. By making expectations and process explicit, I hope it will make it easier for you to contribute.
And you don't just have to write code. You can help out by writing documentation, tests, or even by giving feedback about this work. (And yes, that includes giving feedback about the contribution guidelines.)
Thank you for contributing!
## Contributing and copyright
The project is hosted on [GitHub](https://github.com/SaturnFramework/Saturn) where you can [report issues](https://github.com/SaturnFramework/Saturn/issues), fork
the project and submit pull requests.The library is available under [MIT license](https://github.com/SaturnFramework/Saturn/blob/main/LICENSE.md), which allows modification and redistribution for both commercial and non-commercial purposes.
Please note that this project is released with a [Contributor Code of Conduct](CODE_OF_CONDUCT.md). By participating in this project you agree to abide by its terms.