Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Validation rule to check if operationId nouns conflict with model names #2150

Merged
merged 17 commits into from
Apr 18, 2017

Conversation

dsgouda
Copy link
Contributor

@dsgouda dsgouda commented Apr 12, 2017

Addressing issue #1950


namespace AutoRest.Swagger.Validation
{
public class OperationIdNounPluralizedFormValidation : TypedRule<string>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure about the naming of this class, should be more like "OperationIdNounConflictWithModel" ? What the rule is trying to enforce is not about pluralizing the noun, it's about not conflicting with another name being used for another class name (class name of a model vs. class name of the one containing the operations).

/// <summary>
/// The severity of this message (ie, debug/info/warning/error/fatal, etc)
/// </summary>
public override Category Severity => Category.Error;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's check on this being an Error or not, as I was looking into this rule, I see that AutoRest will disambiguate on its own, calling the class that contains the operations "Operations", and keeping the "" as the name of the class of the model. Since this doesn't cause a code generation problem, but more of a "better name" for customers, it should be a warning in my opinion. Thoughts? @salameer @kirthik @amarzavery

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@olydis thoughts?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agree with @veronicagg. Of course the decision makers might have thought of this and just love our customers very much: Indeed those suffixes are annoying - not only because they are long, but they also sometimes appear/disappear during tiny Swagger revisions (conflicting model definitions was introduced, existing model definition was renamed, etc...), which unnecessarily breaks existing code.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dsgouda maybe my comment wasn't clear enough, I would turn this into a warning at the moment, since it doesn't break code generation. You could also add in the message, if the name is not update, generated code will add a string like "Operations". to disambiguate.

/// <remarks>
/// This may contain placeholders '{0}' for parameterized messages.
/// </remarks>
public override string MessageTemplate => Resources.OperationIdNounPluralizedMessage;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if you update the name of the class, please update this message name also.

public override ValidationCategory ValidationCategory => ValidationCategory.SDKViolation;

/// <summary>
/// This rule passes if the operation id doesn't contain a repeated value before and after the underscore
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this doesn't look like the right comment.

@@ -349,4 +349,7 @@ Modelers:
<data name="ParametersPropertiesValidation" xml:space="preserve">
<value>Parameter Must have the "name" property defined with non-empty string as its value</value>
</data>
<data name="OperationIdNounConflictingModelNamesMessage" xml:space="preserve">
<value>OperationId has a noun that conflicts with one of the model names in definitions section. Consider using the pluralized form for '{0}'</value>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should it be "Consider using the plural form of..." instead of "pluralized ? :)

@@ -0,0 +1,57 @@
{
"swagger": "2.0",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you may want to update the name of the .json file.

@@ -592,6 +592,13 @@ public void EmptyParameterNameValidation()
var messages = ValidateSwagger(Path.Combine(Core.Utilities.Extensions.CodeBaseDirectory, "Resource", "Swagger", "Validation", "empty-parameter-name.json"));
messages.AssertOnlyValidationMessage(typeof(ParameterNameValidation), 2);
}

[Fact]
public void OperationIdNounPluralizedValidationTest()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

could you update the name of the method here?

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License. See License.txt in the project root for license information.

using System;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

could you update the name of the .cs file?

/// <summary>
/// The severity of this message (ie, debug/info/warning/error/fatal, etc)
/// </summary>
public override Category Severity => Category.Error;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dsgouda maybe my comment wasn't clear enough, I would turn this into a warning at the moment, since it doesn't break code generation. You could also add in the message, if the name is not update, generated code will add a string like "Operations". to disambiguate.

@dsgouda dsgouda merged commit 2e1b32f into Azure:master Apr 18, 2017
@dsgouda dsgouda deleted the i1950 branch May 16, 2017 19:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants