Skip to the content.

Mollycoddle Rules

Mollycoddle rules are highly configurable but there are a default set that ship. It is expected that not all of these will match your coding style but then you can change the configuration to suit your own structure.

Note that there are gaps between the numbers to allow for other to be specified, for example if your chosen programming lanugage is py and not c# then creating an alternative ruleset to forbid other filetypes should be simple and can fit in the same rule gap if you wish.

Simplify Code Structure

The following rules help simplify code structure, minimizing mixing up different things in the same location.

MC0001 - C# File Extensions Only.

Only csharp related files are permitted in the project structure.

MC0002 - Lazy File Denylist.

Identifies a common set of lazy mistakes with files.

MC005X - Getting Started Quickly

MC0050 - Readme File Must Exist

A Readme File mus be present in the root of the repo structure.

MC006X - Expected Directories

The following rules help a consistent directory structure at the top level so that it is easy to navigate around a freshly cloned repository and much simpler to get up and running with a new code base.

MC0060 - Source code must live in \src

Only a well known directory structure is permitted at the root level of the repository, this must include \src for the source code.

MC0065 - Permitted Root Folders Only

Only a well known directory structure is permitted at the root level of the repository, only the following folders are permitted at the root level. Note that the primary src folder must exist for MC0060, butt his allows other secondary solutions to be stored with src_ as a prefix.

MC0067 - Permitted Root Files Only

The root of a repository may only contain the readme, a gitignore and gitattributes files alongside folders.

root\readme.md   :: Pass
root\build.yml   :: Fail
root\code.cs     :: Fail
root\.gitignore     :: Pass
root\.gitattributes  :: Pass

MC0070 - Solutions and Projects must live at a consistent level.

Solutions and projects must live at the same level of the folder hierarchy. Solutions must be in the root of a folder that starts with src and csproj files must be under a rooted src folder and one folder level below. E.g. \src\Project\project.csproj

 src\*.sln    :: Pass
 src_*\*.sln    :: Pass
 src\*\\*.csproj   :: Pass
 src\path\path\file.csproj :: Violation
 bonkers\path\file.csproj  :: Violation

Additional option allows for “frameworkversions” folder to group up multitargetting solutions. Where you are not using inline multitargetting all csprojs to support different frameworks must be under a folder called “frameworkversions”. Structure below that is undefined.

 src\**\frameworkversions\**\*.csproj    :: Pass

MC01XX - Consistency Across Teams

Using things like common editorconfig files, gitignore files and so on allows for greater consistency among teams and shift left approach to consistency around code formatting and source code best practices. Its likely that allowing overrides of these files at lower levels in the code base is wise.

MC0100 - Editor Config Must Match Master

Master files ensure that the files in the repos are kept up to date with the most recent changes in style and settings. Editor config ensures that coding style is enforced by the IDE.

MC0101 - Git Ignore Must Match Master

Master files ensure that the files in the repos are kept up to date with the most recent changes in style and settings. Gitignore ensures that sensitive files and files that should not be source managed are skipped.

MC0102 - Nuget.config must match master.

Master files ensure that the files in the repos are kept up to date with the most recent changes in style and settings. Nuget config controls the way that packages are downloaded and should be consistant for an organisation.

MC02XX - Supply Chain Woes

Rules that deal with managing nuget packages specifically but with slots for other package managers.

MC0200 - Banned nuget packages must not be used.

We use preferred packages for consistency and to reduce retraining between solutions. Once we have a nuget package that does a job other nugets that do similar jobs are not preferred.

Only preferred packages may be used.
Alternatives are added to the band list.
Packages which fail security scanning are added to the band list.

Different companies have different rules around how software is permitted for use, in some instances sponsorlink approaches broke those rules and therefore specific packages are excluded.

Moq versions that had sponsorlink included are prohibited.

MC04XXX - Source Repository AntiPatterns

MC0400 - Common Faulting Source Control Files Must Not Exist

There are some files that should not be checked into git, the presence of any of these files immediately after a clean pull from the repository indicates that something is wrong with source control management.

MC05XXX - Bypass and Filter Rules

MC0500 - Archive folder bypass

There is a place where you can dump any old legacy crud that you wish. root\archive is immune to all other molly checks and is totally bypassed therefore any legacy or nasty breachy code you like can live in the archive folder.

MC0501 - Commmon Folder Bypass

\obj, \ndependout, .vs, .git, \bin are all skipped from validation rules.