Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
68e12c8
Add gitignore
Carl-Hugo May 8, 2020
974a5dd
Move OperationResults
Carl-Hugo May 8, 2020
800ffa1
Add solution
Carl-Hugo May 8, 2020
f78f845
Fix serialization of Type
Carl-Hugo Nov 29, 2020
8a6cdce
Simplify props and csproj files
Carl-Hugo Nov 30, 2020
af93205
Move dependency on ProblemDetails to AspNetCore
Carl-Hugo Nov 30, 2020
8e2e79e
Remove invalid namespace
Carl-Hugo Nov 30, 2020
5e93425
Remove MediatR dependency
Carl-Hugo Nov 30, 2020
1dc00e7
Split startup extension in two
Carl-Hugo Nov 30, 2020
0547668
Add a <remarks>
Carl-Hugo Nov 30, 2020
d3e8fdf
Update namespaces
Carl-Hugo Nov 30, 2020
d7d84b4
Add editorconfig
Carl-Hugo Dec 1, 2020
a44b5df
add prettierrc
Carl-Hugo Dec 1, 2020
6e37542
Update PackageProjectUrl
Carl-Hugo Dec 1, 2020
30be771
Add Build, Test, and Deploy GitHub Action
Carl-Hugo Dec 1, 2020
5772af7
Add version.json
Carl-Hugo Dec 1, 2020
3261dc0
Update packages description
Carl-Hugo Dec 1, 2020
84dfaa2
Add repository_dispatch support
Carl-Hugo Dec 2, 2020
8482f3f
Add workflow_dispatch support
Carl-Hugo Dec 2, 2020
bf0093e
Add workflow_dispatch inputs
Carl-Hugo Dec 2, 2020
6c0e6b9
build-and-test should run even during dispatch
Carl-Hugo Dec 2, 2020
42aa36a
Try encapsulate logic in env
Carl-Hugo Dec 2, 2020
19cf6a4
Try encapsulate logic in env
Carl-Hugo Dec 2, 2020
9af8979
Try encapsulate logic in env
Carl-Hugo Dec 2, 2020
d026f8d
Use IS_DISPATCH
Carl-Hugo Dec 2, 2020
a9fd617
Use IS_DISPATCH
Carl-Hugo Dec 2, 2020
0f6bb28
Use IS_DISPATCH
Carl-Hugo Dec 2, 2020
c0fd7fb
echo vars
Carl-Hugo Dec 2, 2020
d17c0d7
try fix env
Carl-Hugo Dec 2, 2020
33752c9
try fix env
Carl-Hugo Dec 2, 2020
d735128
Fix echo
Carl-Hugo Dec 2, 2020
46581d0
Use IS_*_DISPATCH variables
Carl-Hugo Dec 2, 2020
c91f718
Add echo back
Carl-Hugo Dec 2, 2020
0441ac6
echo condition
Carl-Hugo Dec 2, 2020
4f956f6
Replace false by 0
Carl-Hugo Dec 2, 2020
5a8275e
Replace 0 by "false"
Carl-Hugo Dec 2, 2020
0c00a04
Invert condition to IS_NOT_DISPATCH
Carl-Hugo Dec 2, 2020
45b241a
Clean environment variables and usage
Carl-Hugo Dec 2, 2020
90b145e
Move conditions back to steps
Carl-Hugo Dec 2, 2020
cfc7992
Set OriginalObject from ProblemDetailsMessage
Carl-Hugo Dec 3, 2020
1aca379
Fix a failing test
Carl-Hugo Dec 4, 2020
e40e782
Add support for .NET Core 3.1 (Azure Functions)
Carl-Hugo Dec 4, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
237 changes: 237 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,237 @@
#
# Severity: suggestion, warning, error
#
#top-most EditorConfig file
root = true

[*]

#Formatting - indentation
#use soft tabs (spaces) for indentation
indent_style = space

[*.cs]

#Formatting - indentation

#size of soft tabs (spaces)
indent_size = 4
#remove any whitespace characters preceding newline characters
trim_trailing_whitespace = true

#Formatting - indentation options

#indent switch case contents.
csharp_indent_case_contents = true
#indent switch labels
csharp_indent_switch_labels = true

#Formatting - new line options

#place catch statements on a new line
csharp_new_line_before_catch = true
#place else statements on a new line
csharp_new_line_before_else = true
#require finally statements to be on a new line after the closing brace
csharp_new_line_before_finally = true
#require members of object initializers to be on separate lines
csharp_new_line_before_members_in_object_initializers = true
#require members of anonymous types to be on separate lines
csharp_new_line_before_members_in_anonymous_types = true
#require elements of query expression clauses to be on separate lines
csharp_new_line_between_query_expression_clauses = true
#require braces to be on a new line for all expressions ("Allman" style)
csharp_new_line_before_open_brace = all

#Formatting - organize using options

#do not place System.* using directives before other using directives
dotnet_sort_system_directives_first = false

#Formatting - spacing options

#require a space between a cast and the value
csharp_space_after_cast = false
#require a space before the colon for bases or interfaces in a type declaration
csharp_space_after_colon_in_inheritance_clause = true
#require a space after a keyword in a control flow statement such as a for loop
csharp_space_after_keywords_in_control_flow_statements = true
#require a space before the colon for bases or interfaces in a type declaration
csharp_space_before_colon_in_inheritance_clause = true
#remove space within empty argument list parentheses
csharp_space_between_method_call_empty_parameter_list_parentheses = false
#remove space between method call name and opening parenthesis
csharp_space_between_method_call_name_and_opening_parenthesis = false
#do not place space characters after the opening parenthesis and before the closing parenthesis of a method call
csharp_space_between_method_call_parameter_list_parentheses = false
#remove space within empty parameter list parentheses for a method declaration
csharp_space_between_method_declaration_empty_parameter_list_parentheses = false
#place a space character after the opening parenthesis and before the closing parenthesis of a method declaration parameter list.
csharp_space_between_method_declaration_parameter_list_parentheses = false

#Formatting - wrapping options

#leave code block on single line
csharp_preserve_single_line_blocks = true
#leave statements and member declarations on the same line
csharp_preserve_single_line_statements = true

#Style - code block preferences

#prefer curly braces even for one line of code
csharp_prefer_braces = true:suggestion

#Style - expression bodied member options

#prefer block bodies for constructors
csharp_style_expression_bodied_constructors = false:suggestion
#prefer block bodies for methods
csharp_style_expression_bodied_methods = false:suggestion
#prefer expression-bodied members for properties
csharp_style_expression_bodied_properties = true:suggestion

#Style - expression level options

#prefer the language keyword for member access expressions, instead of the type name, for types that have a keyword to represent them
dotnet_style_predefined_type_for_member_access = true:error

#Style - expression-level preferences

#prefer objects to be initialized using object initializers when possible
dotnet_style_object_initializer = true:suggestion
#prefer collections to be initialized using collection initializers when possible
dotnet_style_collection_initializer = true:suggestion
#prefer tuple names to ItemX properties
dotnet_style_explicit_tuple_names = true:error
#prefer inferred tuple element names
dotnet_style_prefer_inferred_tuple_names = true:warning
#prefer inferred anonymous type member names
dotnet_style_prefer_inferred_anonymous_type_member_names = true:warning
#prefer autoproperties over properties with private backing fields
dotnet_style_prefer_auto_properties = true:warning
#prefer assignments with a ternary conditional over an if-else statement
dotnet_style_prefer_conditional_expression_over_assignment = false:suggestion
#prefer return statements to use a ternary conditional over an if-else statement
dotnet_style_prefer_conditional_expression_over_return = false
#prefer using a null check with pattern-matching over object.ReferenceEquals
dotnet_style_prefer_is_null_check_over_reference_equality_method = true:error

#Style - implicit and explicit types

#prefer var is used to declare variables with built-in system types such as int
csharp_style_var_for_built_in_types = true:warning
#prefer var when the type is already mentioned on the right-hand side of a declaration expression
csharp_style_var_when_type_is_apparent = true:warning
#prefer var is used to declare variables over explicit type in all cases, unless overridden by another code style rule
csharp_style_var_elsewhere = true:warning

#Style - language keyword and framework type options

#prefer the language keyword for local variables, method parameters, and class members, instead of the type name, for types that have a keyword to represent them
dotnet_style_predefined_type_for_locals_parameters_members = true:error

#Style - qualification options

#prefer fields not to be prefaced with This
dotnet_style_qualification_for_field = false:error
##prefer methods not to be prefaced with This
dotnet_style_qualification_for_method = false:error
##prefer properties not to be prefaced with This
dotnet_style_qualification_for_property = false:error
##prefer events not to be prefaced with This
dotnet_style_qualification_for_event = false:error

#Style - modifier preferences

#prefer accessibility modifiers to be specified
dotnet_style_require_accessibility_modifiers = always:error
#when this rule is set to a list of modifiers, prefer the specified ordering
csharp_preferred_modifier_order = public,private,protected,internal,static,extern,new,virtual,abstract,sealed,override,readonly,unsafe,volatile,async:suggestion

#Style - parentheses preferences

#prefer parentheses to clarify arithmetic operator(*, /, %, +, -, <<, >>, &, ^, |) precedence
dotnet_style_parentheses_in_arithmetic_binary_operators = never_if_unnecessary:suggestion
#prefer parentheses to clarify relational operator (>, <, <=, >=, is, as, ==, !=) precedence
dotnet_style_parentheses_in_relational_binary_operators = always_for_clarity:suggestion
#prefer parentheses to clarify other binary operator (&&, ||, ??) precedence
dotnet_style_parentheses_in_other_binary_operators = never_if_unnecessary:suggestion
#prefer parentheses to clarify operator precedence
dotnet_style_parentheses_in_other_operators = never_if_unnecessary:suggestion

#Naming rules

#async methods are PascalCase and end with Async
dotnet_naming_rule.async_methods_should_end_in_async.severity = error
dotnet_naming_rule.async_methods_should_end_in_async.symbols = async_methods
dotnet_naming_rule.async_methods_should_end_in_async.style = async_methods_style

dotnet_naming_symbols.async_methods.applicable_kinds = method
dotnet_naming_symbols.async_methods.applicable_accessibilities = *
dotnet_naming_symbols.async_methods.required_modifiers = async

dotnet_naming_style.async_methods_style.capitalization = pascal_case
dotnet_naming_style.async_methods_style.required_suffix = Async


#private fields are camelCase and start with _
dotnet_naming_rule.private_fields_should_be_camel_case.severity = error
dotnet_naming_rule.private_fields_should_be_camel_case.symbols = private_fields
dotnet_naming_rule.private_fields_should_be_camel_case.style = private_field_style

dotnet_naming_symbols.private_fields.applicable_kinds = field
dotnet_naming_symbols.private_fields.applicable_accessibilities = private

dotnet_naming_style.private_field_style.required_prefix = _
dotnet_naming_style.private_field_style.capitalization = camel_case


#methods are PascalCase
dotnet_naming_rule.methods_should_be_pascal_case.severity = error
dotnet_naming_rule.methods_should_be_pascal_case.symbols = methods
dotnet_naming_rule.methods_should_be_pascal_case.style = methods_style

dotnet_naming_symbols.methods.applicable_kinds = method
dotnet_naming_symbols.methods.applicable_accessibilities = *

dotnet_naming_style.methods_style.capitalization = pascal_case


#classes are PacalCase
dotnet_naming_rule.classes_should_be_pascal_case.severity = error
dotnet_naming_rule.classes_should_be_pascal_case.symbols = classes
dotnet_naming_rule.classes_should_be_pascal_case.style = classes_style

dotnet_naming_symbols.classes.applicable_kinds = class
dotnet_naming_symbols.classes.applicable_accessibilities = *

dotnet_naming_style.classes_style.capitalization = pascal_case


#parameters are camelCase
dotnet_naming_rule.parameters_should_be_camel_case.severity = error
dotnet_naming_rule.parameters_should_be_camel_case.symbols = parameters
dotnet_naming_rule.parameters_should_be_camel_case.style = parameters_style

dotnet_naming_symbols.parameters.applicable_kinds = parameter

dotnet_naming_style.parameters_style.capitalization = camel_case


#interfaces are PacalCase and start with I
dotnet_naming_rule.interfaces_should_be_pascal_case.severity = error
dotnet_naming_rule.interfaces_should_be_pascal_case.symbols = interfaces
dotnet_naming_rule.interfaces_should_be_pascal_case.style = interfaces_style

dotnet_naming_symbols.interfaces.applicable_kinds = interface
dotnet_naming_symbols.interfaces.applicable_accessibilities = *

dotnet_naming_style.interfaces_style.capitalization = pascal_case
dotnet_naming_style.interfaces_style.required_prefix = I


# private fields and Async methods naming are optional for tests.
# this allows to declare `private sut` and name async test without the `Async` suffix.
[**/*.{Tests,IntegrationTests,FunctionalTests}/**.cs]
dotnet_naming_rule.private_fields_should_be_camel_case.severity = suggestion
dotnet_naming_rule.async_methods_should_end_in_async.severity = suggestion
98 changes: 98 additions & 0 deletions .github/workflows/master.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
name: Build, Test, and Deploy

on:
push:
branches:
- master
- main
paths-ignore:
- 'samples/**'

pull_request:
branches:
- master
- main

repository_dispatch:
types:
- deploy

workflow_dispatch:
inputs:
deployToFeedz:
description: 'Set to `true` to deploy to Feedz.io'
required: false
default: ''
deployToNuget:
description: 'Set to `true` to deploy to NuGet.org'
required: false
default: ''

env:
DOTNET_2_VERSION: '2.1.x'
DOTNET_3_VERSION: '3.1.x'
DOTNET_5_VERSION: '5.0.x'
BUILD_CONFIGURATION: Release
FEEDZ_URI: https://f.feedz.io/forevolve/operationresults/nuget/index.json
ACTIONS_ALLOW_UNSECURE_COMMANDS: true

jobs:
build-and-test:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
dotnet: ['5.0.x']
env:
IS_NOT_DISPATCH: ${{ github.event_name != 'repository_dispatch' && github.event_name != 'workflow_dispatch' }}

steps:
- uses: actions/checkout@v1
if: env.IS_NOT_DISPATCH

- name: Setup .NET Core
if: env.IS_NOT_DISPATCH
uses: actions/setup-dotnet@v1
with:
dotnet-version: ${{ matrix.dotnet }}

- name: Build
if: env.IS_NOT_DISPATCH
run: dotnet build --configuration ${{ env.BUILD_CONFIGURATION }}

- name: Unit Test
if: env.IS_NOT_DISPATCH
run: dotnet test --configuration ${{ env.BUILD_CONFIGURATION }}

deploy:
runs-on: ubuntu-latest
needs: build-and-test
strategy:
fail-fast: true
matrix:
dotnet: ['5.0.x']

steps:
- uses: actions/checkout@v1
with:
ref: ${{ github.event.client_payload.ref }}

- name: Setup .NET Core
uses: actions/setup-dotnet@v1
with:
dotnet-version: ${{ matrix.dotnet }}

- uses: dotnet/nbgv@master
with:
setAllVars: true

- name: Pack
run: dotnet pack --configuration ${{ env.BUILD_CONFIGURATION }}

- name: Push to feedz.io
run: dotnet nuget push **/*.nupkg -k ${{ secrets.FEEDZ_API_KEY }} -s ${{ env.FEEDZ_URI }}
if: github.event_name == 'pull_request' || (github.event_name == 'repository_dispatch' && github.event.client_payload.feedz == true) || (github.event_name == 'workflow_dispatch' && github.event.inputs.deployToFeedz == 'true')

- name: Push to NuGet.org
run: dotnet nuget push **/*.nupkg -k ${{ secrets.NUGET_API_KEY }} -s https://api.nuget.org/v3/index.json
if: github.event_name == 'push' || (github.event_name == 'repository_dispatch' && github.event.client_payload.nuget == true) || (github.event_name == 'workflow_dispatch' && github.event.inputs.deployToNuget == 'true')
Loading