From 6a97ddb42f84801f7e630ae83eab5054217a632e Mon Sep 17 00:00:00 2001 From: gregwinterstein <68340656+gregwinterstein@users.noreply.github.com> Date: Thu, 31 Aug 2023 04:20:00 -0700 Subject: [PATCH 1/2] Make odata-cli honor internal option (issue #268) (#361) --- src/Microsoft.OData.Cli/GenerateCommand.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Microsoft.OData.Cli/GenerateCommand.cs b/src/Microsoft.OData.Cli/GenerateCommand.cs index d7ae6b3a..38ef5646 100644 --- a/src/Microsoft.OData.Cli/GenerateCommand.cs +++ b/src/Microsoft.OData.Cli/GenerateCommand.cs @@ -87,9 +87,9 @@ public GenerateCommand() this.AddOption(upperCamelCase); - Option internalModifier = new Option(new[] { "--internal", "-i" }) + Option internalModifier = new Option(new[] { "--enable-internal", "-i" }) { - Name = "internal", + Name = "enable-internal", Description = "Apply the \"internal\" class modifier on generated classes instead of \"public\" thereby making them invisible outside the assembly." }; From 46241bba715de691ed0b9c872ab0cdcb56577d9a Mon Sep 17 00:00:00 2001 From: gregwinterstein <68340656+gregwinterstein@users.noreply.github.com> Date: Thu, 28 Sep 2023 21:53:55 -0700 Subject: [PATCH 2/2] Add no timestamp option (issue #349) (#362) --- src/Microsoft.OData.Cli/GenerateCommand.cs | 9 ++++ src/Microsoft.OData.Cli/GenerateOptions.cs | 5 ++ .../CodeGeneration/V4CodeGenDescriptor.cs | 10 ++-- .../Microsoft.OData.CodeGen.csproj | 1 - .../Models/ServiceConfiguration.cs | 3 +- .../Templates/ODataT4CodeGenerator.cs | 41 +++++++++++++-- .../Templates/ODataT4CodeGenerator.tt | 3 ++ .../Templates/ODataT4CodeGenerator.ttinclude | 33 +++++++++++- .../Models/UserSettings.cs | 13 +++++ .../ODataConnectedServiceWizard.cs | 4 +- .../Views/AdvancedSettings.xaml | 4 ++ .../CodeGeneration/CodeGenDescriptorTest.cs | 7 ++- .../TestConfigAllOptionsSet.txt | 3 ++ .../CodeGeneration/TestConfigBasic.txt | 3 ++ .../CodeGeneration/TestConfigBasicVB.txt | 3 ++ .../Common/ExtensionMethodsTests.cs | 4 ++ .../ODataConnectedServiceWizardTests.cs | 42 +++++++++------ .../Templates/ODataT4CodeGeneratorTest.cs | 52 ++++++++++++++++++- .../Templates/ODataT4CodeGeneratorTests.cs | 45 ++++++---------- .../TestHelpers/GeneratedCodeHelpers.cs | 43 +++++++++++---- .../Views/UserSettingsTest.cs | 4 +- 21 files changed, 261 insertions(+), 71 deletions(-) diff --git a/src/Microsoft.OData.Cli/GenerateCommand.cs b/src/Microsoft.OData.Cli/GenerateCommand.cs index 38ef5646..05b15093 100644 --- a/src/Microsoft.OData.Cli/GenerateCommand.cs +++ b/src/Microsoft.OData.Cli/GenerateCommand.cs @@ -95,6 +95,14 @@ public GenerateCommand() this.AddOption(internalModifier); + Option noTimestamp = new Option(new[] { "--no-timestamp", "-nt" }) + { + Name = "no-timestamp", + Description = "Omit generation timestamp in generated files.", + }; + noTimestamp.SetDefaultValue(false); + this.AddOption(noTimestamp); + Option multipleFiles = new Option(new[] { "--multiple-files" }) { Name = "multiple-files", @@ -240,6 +248,7 @@ private async Task GenerateCodeForV4Clients(GenerateOptions generateOptions, ICo serviceConfigurationV4.IgnoreUnexpectedElementsAndAttributes = generateOptions.IgnoreUnexpectedElements; serviceConfigurationV4.EnableNamingAlias = generateOptions.UpperCamelCase; serviceConfigurationV4.UseDataServiceCollection = generateOptions.EnableTracking; + serviceConfigurationV4.NoTimestamp = generateOptions.NoTimestamp; Project project = ProjectHelper.CreateProjectInstance(generateOptions.OutputDir); BaseCodeGenDescriptor codeGenDescriptor = new CodeGenDescriptorFactory().Create( diff --git a/src/Microsoft.OData.Cli/GenerateOptions.cs b/src/Microsoft.OData.Cli/GenerateOptions.cs index e330008b..ee2bf22c 100644 --- a/src/Microsoft.OData.Cli/GenerateOptions.cs +++ b/src/Microsoft.OData.Cli/GenerateOptions.cs @@ -43,6 +43,11 @@ public class GenerateOptions /// public bool EnableTracking { get; set; } + /// + /// Omit generation timestamp in generated files. + /// + public bool NoTimestamp { get; set; } + /// /// Disables/Enables upper camel casing /// diff --git a/src/Microsoft.OData.CodeGen/CodeGeneration/V4CodeGenDescriptor.cs b/src/Microsoft.OData.CodeGen/CodeGeneration/V4CodeGenDescriptor.cs index 2c8e764e..11b3308a 100644 --- a/src/Microsoft.OData.CodeGen/CodeGeneration/V4CodeGenDescriptor.cs +++ b/src/Microsoft.OData.CodeGen/CodeGeneration/V4CodeGenDescriptor.cs @@ -28,7 +28,6 @@ public V4CodeGenDescriptor(IFileHandler fileHandler, IMessageLogger logger, IPac { ClientNuGetPackageName = Common.Constants.V4ClientNuGetPackage; ClientDocUri = Common.Constants.V4DocUri; - // ServiceConfiguration = base.ServiceConfiguration as ServiceConfigurationV4; CodeGeneratorFactory = codeGeneratorFactory; } @@ -95,7 +94,7 @@ private async Task AddT4FileAsync(string metadata, string outputDirectory, Langu await writer.WriteLineAsync(""); } - await FileHandler.AddFileAsync(csdlTempFile, metadataFile, new ODataFileOptions { SuppressOverwritePrompt = true}); + await FileHandler.AddFileAsync(csdlTempFile, metadataFile, new ODataFileOptions { SuppressOverwritePrompt = true }); FileHandler.SetFileAsEmbeddedResource(csdlFileName); @@ -162,12 +161,13 @@ private async Task AddGeneratedCodeAsync(string metadata, string outputDirectory t4CodeGenerator.EnableNamingAlias = serviceConfiguration.EnableNamingAlias; t4CodeGenerator.NamespacePrefix = serviceConfiguration.NamespacePrefix; t4CodeGenerator.MakeTypesInternal = serviceConfiguration.MakeTypesInternal; + t4CodeGenerator.NoTimestamp = serviceConfiguration.NoTimestamp; t4CodeGenerator.GenerateMultipleFiles = serviceConfiguration.GenerateMultipleFiles; t4CodeGenerator.ExcludedOperationImports = serviceConfiguration.ExcludedOperationImports; t4CodeGenerator.ExcludedBoundOperations = serviceConfiguration.ExcludedBoundOperations; t4CodeGenerator.ExcludedSchemaTypes = serviceConfiguration.ExcludedSchemaTypes; var headers = new List(); - if (serviceConfiguration.CustomHttpHeaders !=null) + if (serviceConfiguration.CustomHttpHeaders != null) { var headerElements = serviceConfiguration.CustomHttpHeaders.Split(new string[] { Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries); foreach (var headerElement in headerElements) @@ -191,7 +191,7 @@ private async Task AddGeneratedCodeAsync(string metadata, string outputDirectory // Csdl file name is this format [ServiceName]Csdl.xml var csdlFileName = string.Concat(serviceConfiguration.ServiceName, Common.Constants.CsdlFileNameSuffix); var metadataFile = Path.Combine(referenceFolder, csdlFileName); - await FileHandler.AddFileAsync(tempFile, metadataFile, new ODataFileOptions { SuppressOverwritePrompt = true}); + await FileHandler.AddFileAsync(tempFile, metadataFile, new ODataFileOptions { SuppressOverwritePrompt = true }); FileHandler.SetFileAsEmbeddedResource(csdlFileName); t4CodeGenerator.EmitContainerPropertyAttribute = FileHandler.EmitContainerPropertyAttribute(); @@ -213,7 +213,7 @@ private async Task AddGeneratedCodeAsync(string metadata, string outputDirectory } var outputFile = Path.Combine(referenceFolder, $"{this.GeneratedFileNamePrefix(serviceConfiguration.GeneratedFileNamePrefix)}{(languageOption == LanguageOption.GenerateCSharpCode ? ".cs" : ".vb")}"); - await FileHandler.AddFileAsync(tempFile, outputFile, new ODataFileOptions { SuppressOverwritePrompt = true}); + await FileHandler.AddFileAsync(tempFile, outputFile, new ODataFileOptions { SuppressOverwritePrompt = true }); t4CodeGenerator.MultipleFilesManager?.GenerateFiles(serviceConfiguration.GenerateMultipleFiles, FileHandler, MessageLogger, referenceFolder, true, serviceConfiguration.OpenGeneratedFilesInIDE); await MessageLogger.WriteMessageAsync(LogMessageCategory.Information, "Client Proxy for OData V4 was generated."); } diff --git a/src/Microsoft.OData.CodeGen/Microsoft.OData.CodeGen.csproj b/src/Microsoft.OData.CodeGen/Microsoft.OData.CodeGen.csproj index fd41522c..e71bc051 100644 --- a/src/Microsoft.OData.CodeGen/Microsoft.OData.CodeGen.csproj +++ b/src/Microsoft.OData.CodeGen/Microsoft.OData.CodeGen.csproj @@ -83,7 +83,6 @@ - diff --git a/src/Microsoft.OData.CodeGen/Models/ServiceConfiguration.cs b/src/Microsoft.OData.CodeGen/Models/ServiceConfiguration.cs index 371eedbf..0fd5dacb 100644 --- a/src/Microsoft.OData.CodeGen/Models/ServiceConfiguration.cs +++ b/src/Microsoft.OData.CodeGen/Models/ServiceConfiguration.cs @@ -32,7 +32,7 @@ public class ServiceConfiguration public string WebProxyNetworkCredentialsDomain { get; set; } public bool IncludeCustomHeaders { get; set; } public bool StoreCustomHttpHeaders { get; set; } - public List ExcludedSchemaTypes { get; set; } + public List ExcludedSchemaTypes { get; set; } } @@ -43,5 +43,6 @@ public class ServiceConfigurationV4 : ServiceConfiguration public bool IncludeT4File { get; set; } public List ExcludedOperationImports { get; set; } public List ExcludedBoundOperations { get; set; } + public bool NoTimestamp { get; set; } } } diff --git a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.cs b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.cs index bd25ae49..f03afe14 100644 --- a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.cs +++ b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.cs @@ -73,6 +73,7 @@ public virtual string TransformText() MetadataFileRelativePath = this.MetadataFileRelativePath, MakeTypesInternal = this.MakeTypesInternal, MultipleFilesManager = new FilesManager(null), + NoTimestamp = this.NoTimestamp, GenerateMultipleFiles = this.GenerateMultipleFiles, ExcludedOperationImports = this.ExcludedOperationImports, ExcludedBoundOperations = this.ExcludedBoundOperations, @@ -113,6 +114,7 @@ public virtual string TransformText() MetadataFileRelativePath = this.MetadataFileRelativePath, MakeTypesInternal = this.MakeTypesInternal, MultipleFilesManager = new FilesManager(null), + NoTimestamp = this.NoTimestamp, GenerateMultipleFiles = this.GenerateMultipleFiles, ExcludedOperationImports = this.ExcludedOperationImports, ExcludedBoundOperations = this.ExcludedBoundOperations, @@ -204,6 +206,9 @@ public static class Configuration // thereby making them invisible outside the assembly public const bool MakeTypesInternal = false; + // If set to true, generation timestamps will be left out of generated files + public const bool NoTimestamp = false; + //This files indicates whether to generate the files into multiple files or single. //If set to true then multiple files will be generated. Otherwise only a single file is generated. public const bool GenerateMultipleFiles = false; @@ -391,6 +396,15 @@ public bool MakeTypesInternal set; } +/// +/// true to omit generation timestamp; otherwise false. +/// +public bool NoTimestamp +{ + get; + set; +} + private IEnumerable excludedOperationImports = new List(); /// @@ -735,6 +749,7 @@ private void ApplyParametersFromConfigurationClass() this.EnableNamingAlias = Configuration.EnableNamingAlias; this.IgnoreUnexpectedElementsAndAttributes = Configuration.IgnoreUnexpectedElementsAndAttributes; this.MakeTypesInternal = Configuration.MakeTypesInternal; + this.NoTimestamp = Configuration.NoTimestamp; this.MetadataFilePath = Configuration.MetadataFilePath; this.MetadataFileRelativePath = Configuration.MetadataFileRelativePath; this.GenerateMultipleFiles = Configuration.GenerateMultipleFiles; @@ -1188,6 +1203,15 @@ public bool MakeTypesInternal set; } + /// + /// true to omit generation timestamp; otherwise false. + /// + public bool NoTimestamp + { + get; + set; + } + /// /// list of operation imports to omit from the generated code /// @@ -4155,14 +4179,20 @@ internal override void WriteFileHeader() this.Write("\r\n//\r\n// Changes to this file may cause incorrect behavior and will be lost i" + "f\r\n// the code is regenerated.\r\n// \r\n//--------------------" + - "----------------------------------------------------------\r\n\r\n// Generation date" + - ": "); + "----------------------------------------------------------\r\n\r\n"); + + + if (!this.context.NoTimestamp) + { + +this.Write("// Generation date: "); this.Write(this.ToStringHelper.ToStringWithCulture(DateTime.Now.ToString(global::System.Globalization.CultureInfo.CurrentCulture))); this.Write("\r\n"); + } } internal override void WriteNamespaceStart(string fullNamespace) @@ -6296,15 +6326,20 @@ internal override void WriteFileHeader() Option Strict Off Option Explicit On +"); -'Generation date: "); + if (!this.context.NoTimestamp) + { + +this.Write("\'Generation date: "); this.Write(this.ToStringHelper.ToStringWithCulture(DateTime.Now.ToString(System.Globalization.CultureInfo.CurrentCulture))); this.Write("\r\n"); + } } internal override void WriteNamespaceStart(string fullNamespace) diff --git a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.tt b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.tt index fce2ffec..cb290067 100644 --- a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.tt +++ b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.tt @@ -36,6 +36,9 @@ public static class Configuration // thereby making them invisible outside the assembly public const bool MakeTypesInternal = false; + // If set to true, generation timestamps will be left out of generated files + public const bool NoTimestamp = false; + //This files indicates whether to generate the files into multiple files or single. //If set to true then multiple files will be generated. Otherwise only a single file is generated. public const bool GenerateMultipleFiles = false; diff --git a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.ttinclude b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.ttinclude index 4a6e57b0..6a4ca928 100644 --- a/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.ttinclude +++ b/src/Microsoft.OData.CodeGen/Templates/ODataT4CodeGenerator.ttinclude @@ -52,6 +52,7 @@ MetadataFileRelativePath = this.MetadataFileRelativePath, MakeTypesInternal = this.MakeTypesInternal, MultipleFilesManager = new FilesManager(null), + NoTimestamp = this.NoTimestamp, GenerateMultipleFiles = this.GenerateMultipleFiles, ExcludedOperationImports = this.ExcludedOperationImports, ExcludedBoundOperations = this.ExcludedBoundOperations, @@ -92,6 +93,7 @@ MetadataFileRelativePath = this.MetadataFileRelativePath, MakeTypesInternal = this.MakeTypesInternal, MultipleFilesManager = new FilesManager(null), + NoTimestamp = this.NoTimestamp, GenerateMultipleFiles = this.GenerateMultipleFiles, ExcludedOperationImports = this.ExcludedOperationImports, ExcludedBoundOperations = this.ExcludedBoundOperations, @@ -249,6 +251,15 @@ public bool MakeTypesInternal set; } +/// +/// true to omit generation timestamp; otherwise false. +/// +public bool NoTimestamp +{ + get; + set; +} + private IEnumerable excludedOperationImports = new List(); /// @@ -593,6 +604,7 @@ private void ApplyParametersFromConfigurationClass() this.EnableNamingAlias = Configuration.EnableNamingAlias; this.IgnoreUnexpectedElementsAndAttributes = Configuration.IgnoreUnexpectedElementsAndAttributes; this.MakeTypesInternal = Configuration.MakeTypesInternal; + this.NoTimestamp = Configuration.NoTimestamp; this.MetadataFilePath = Configuration.MetadataFilePath; this.MetadataFileRelativePath = Configuration.MetadataFileRelativePath; this.GenerateMultipleFiles = Configuration.GenerateMultipleFiles; @@ -1046,6 +1058,15 @@ public class CodeGenerationContext set; } + /// + /// true to omit generation timestamp; otherwise false. + /// + public bool NoTimestamp + { + get; + set; + } + /// /// list of operation imports to omit from the generated code /// @@ -4014,9 +4035,14 @@ public sealed class ODataClientCSharpTemplate : ODataClientTemplate // //------------------------------------------------------------------------------ +<#+ + if (!this.context.NoTimestamp) + { +#> // Generation date: <#= DateTime.Now.ToString(global::System.Globalization.CultureInfo.CurrentCulture) #> <#+ } + } internal override void WriteNamespaceStart(string fullNamespace) { @@ -5211,11 +5237,14 @@ public sealed class ODataClientVBTemplate : ODataClientTemplate Option Strict Off Option Explicit On - - +<#+ + if (!this.context.NoTimestamp) + { +#> 'Generation date: <#= DateTime.Now.ToString(System.Globalization.CultureInfo.CurrentCulture) #> <#+ } + } internal override void WriteNamespaceStart(string fullNamespace) { diff --git a/src/ODataConnectedService.Shared/Models/UserSettings.cs b/src/ODataConnectedService.Shared/Models/UserSettings.cs index c5adc756..688f9b91 100644 --- a/src/ODataConnectedService.Shared/Models/UserSettings.cs +++ b/src/ODataConnectedService.Shared/Models/UserSettings.cs @@ -65,6 +65,8 @@ public class UserSettings : INotifyPropertyChanged private bool ignoreUnexpectedElementsAndAttributes; + private bool noTimestamp; + private bool includeT4File; private bool includeWebProxy; @@ -236,6 +238,17 @@ public bool IgnoreUnexpectedElementsAndAttributes } } + [DataMember] + public bool NoTimestamp + { + get { return noTimestamp; } + set + { + noTimestamp = value; + OnPropertyChanged(); + } + } + [DataMember] public bool IncludeT4File { diff --git a/src/ODataConnectedService.Shared/ODataConnectedServiceWizard.cs b/src/ODataConnectedService.Shared/ODataConnectedServiceWizard.cs index 9e3493f0..1705e026 100644 --- a/src/ODataConnectedService.Shared/ODataConnectedServiceWizard.cs +++ b/src/ODataConnectedService.Shared/ODataConnectedServiceWizard.cs @@ -11,12 +11,11 @@ using System.Threading.Tasks; using Microsoft.OData.CodeGen.Common; using Microsoft.OData.CodeGen.Models; -using Microsoft.OData.CodeGen; +using Microsoft.OData.ConnectedService.Common; using Microsoft.OData.ConnectedService.ViewModels; using Microsoft.OData.ConnectedService.Views; using Microsoft.OData.Edm; using Microsoft.VisualStudio.ConnectedServices; -using Microsoft.OData.ConnectedService.Common; namespace Microsoft.OData.ConnectedService { @@ -187,6 +186,7 @@ public void AdvancedSettingsViewModel_PageEntering(object sender, EventArgs args if (ServiceConfig.EdmxVersion == Constants.EdmxVersion4) { + advancedSettings.NoTimestamp.IsEnabled = !Context.IsUpdating; advancedSettings.IncludeT4File.IsEnabled = !Context.IsUpdating; } } diff --git a/src/ODataConnectedService.Shared/Views/AdvancedSettings.xaml b/src/ODataConnectedService.Shared/Views/AdvancedSettings.xaml index 523418ca..f6946e77 100644 --- a/src/ODataConnectedService.Shared/Views/AdvancedSettings.xaml +++ b/src/ODataConnectedService.Shared/Views/AdvancedSettings.xaml @@ -50,6 +50,10 @@ HorizontalAlignment="Left" VerticalAlignment="Top" Margin="0, 5"> Make generated types internal (Enable this if you don't want to expose the generated types outside of your assembly.) + + Omit generation timestamp in generated files (Enable this if you don't need generation timestamps in generated files.) + ClientCodeServiceConfigToCodeGeneratorData UseNamespacePrefix = true, NamespacePrefix = "Namespace", MakeTypesInternal = true, + NoTimestamp = true, GeneratedFileNamePrefix = "GeneratedCode", GenerateMultipleFiles = true, OpenGeneratedFilesInIDE = true, @@ -104,6 +105,7 @@ public static IEnumerable ClientCodeServiceConfigToCodeGeneratorData UseNamespacePrefix = false, NamespacePrefix = "Namespace", MakeTypesInternal = false, + NoTimestamp = false, GeneratedFileNamePrefix = "Reference", GenerateMultipleFiles = false, OpenGeneratedFilesInIDE = false, @@ -137,6 +139,7 @@ public void TestAddGeneratedClientCode_PassesServiceConfigOptionsToCodeGenerator Assert.AreEqual(serviceConfig.EnableNamingAlias, generator.EnableNamingAlias); Assert.AreEqual(serviceConfig.IgnoreUnexpectedElementsAndAttributes, generator.IgnoreUnexpectedElementsAndAttributes); Assert.AreEqual(serviceConfig.MakeTypesInternal, generator.MakeTypesInternal); + Assert.AreEqual(serviceConfig.NoTimestamp, generator.NoTimestamp); Assert.AreEqual(serviceConfig.NamespacePrefix, generator.NamespacePrefix); Assert.AreEqual(serviceConfig.ExcludedOperationImports, generator.ExcludedOperationImports); Assert.AreEqual(serviceConfig.ExcludedSchemaTypes, generator.ExcludedSchemaTypes); @@ -328,7 +331,7 @@ public void TestAddGeneratedClientCode_GeneratesT4TemplateFiles(string lang, str { languageOption = ODataT4CodeGenerator.LanguageOption.CSharp; } - else + else { languageOption = ODataT4CodeGenerator.LanguageOption.VB; } @@ -877,7 +880,7 @@ public TestV4CodeGenDescriptor(IFileHandler fileHandler, IMessageLogger messageL } } - class TestV3CodeGenDescriptor: V3CodeGenDescriptor + class TestV3CodeGenDescriptor : V3CodeGenDescriptor { public TestV3CodeGenDescriptor(IFileHandler fileHandler, IMessageLogger messageLogger, IPackageInstaller packageInstaller) : base(fileHandler, messageLogger, packageInstaller) { diff --git a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigAllOptionsSet.txt b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigAllOptionsSet.txt index 59fac704..1bc3961b 100644 --- a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigAllOptionsSet.txt +++ b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigAllOptionsSet.txt @@ -36,6 +36,9 @@ public static class Configuration // thereby making them invisible outside the assembly public const bool MakeTypesInternal = true; + // If set to true, generation timestamps will be left out of generated files + public const bool NoTimestamp = true; + //This files indicates whether to generate the files into multiple files or single. //If set to true then multiple files will be generated. Otherwise only a single file is generated. public const bool GenerateMultipleFiles = true; diff --git a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasic.txt b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasic.txt index 0378a702..2dfd1c4c 100644 --- a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasic.txt +++ b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasic.txt @@ -36,6 +36,9 @@ public static class Configuration // thereby making them invisible outside the assembly public const bool MakeTypesInternal = false; + // If set to true, generation timestamps will be left out of generated files + public const bool NoTimestamp = false; + //This files indicates whether to generate the files into multiple files or single. //If set to true then multiple files will be generated. Otherwise only a single file is generated. public const bool GenerateMultipleFiles = false; diff --git a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasicVB.txt b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasicVB.txt index 78ef5e22..937364fe 100644 --- a/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasicVB.txt +++ b/test/ODataConnectedService.Tests/CodeGeneration/TestConfigBasicVB.txt @@ -36,6 +36,9 @@ public static class Configuration // thereby making them invisible outside the assembly public const bool MakeTypesInternal = false; + // If set to true, generation timestamps will be left out of generated files + public const bool NoTimestamp = false; + //This files indicates whether to generate the files into multiple files or single. //If set to true then multiple files will be generated. Otherwise only a single file is generated. public const bool GenerateMultipleFiles = false; diff --git a/test/ODataConnectedService.Tests/Common/ExtensionMethodsTests.cs b/test/ODataConnectedService.Tests/Common/ExtensionMethodsTests.cs index 936c5171..8f430f5d 100644 --- a/test/ODataConnectedService.Tests/Common/ExtensionMethodsTests.cs +++ b/test/ODataConnectedService.Tests/Common/ExtensionMethodsTests.cs @@ -33,6 +33,7 @@ private static UserSettings CreateUserSettings() userSettings.IncludeWebProxy = true; userSettings.IncludeWebProxyNetworkCredentials = true; userSettings.MakeTypesInternal = true; + userSettings.NoTimestamp = true; userSettings.NamespacePrefix = "Test"; userSettings.OpenGeneratedFilesInIDE = true; userSettings.ServiceName = "Test"; @@ -65,6 +66,7 @@ private static ServiceConfigurationV4 CreateServiceConfiguration() serviceConfig.IncludeWebProxy = true; serviceConfig.IncludeWebProxyNetworkCredentials = true; serviceConfig.MakeTypesInternal = true; + serviceConfig.NoTimestamp = true; serviceConfig.NamespacePrefix = "Test"; serviceConfig.OpenGeneratedFilesInIDE = true; serviceConfig.ServiceName = "Test"; @@ -101,6 +103,7 @@ public void TestCopyPropertiesFromUserSettingsToServiceConfiguration() Assert.True(serviceConfig.IncludeWebProxy); Assert.True(serviceConfig.IncludeWebProxyNetworkCredentials); Assert.True(serviceConfig.MakeTypesInternal); + Assert.True(serviceConfig.NoTimestamp); Assert.Equal("Test", serviceConfig.NamespacePrefix); Assert.True(serviceConfig.OpenGeneratedFilesInIDE); Assert.Equal("Test", serviceConfig.ServiceName); @@ -135,6 +138,7 @@ public void TestCopyPropertiesFromServiceConfigurationToUserSettings() Assert.True(userSettings.IncludeWebProxy); Assert.True(userSettings.IncludeWebProxyNetworkCredentials); Assert.True(userSettings.MakeTypesInternal); + Assert.True(userSettings.NoTimestamp); Assert.Equal("Test", userSettings.NamespacePrefix); Assert.True(userSettings.OpenGeneratedFilesInIDE); Assert.Equal("Test", userSettings.ServiceName); diff --git a/test/ODataConnectedService.Tests/ODataConnectedServiceWizardTests.cs b/test/ODataConnectedService.Tests/ODataConnectedServiceWizardTests.cs index 8d814ffa..1909887a 100644 --- a/test/ODataConnectedService.Tests/ODataConnectedServiceWizardTests.cs +++ b/test/ODataConnectedService.Tests/ODataConnectedServiceWizardTests.cs @@ -14,19 +14,18 @@ using System.Windows; using System.Windows.Documents; using FluentAssertions; +using Microsoft.OData.CodeGen.Common; +using Microsoft.OData.CodeGen.Models; using Microsoft.OData.ConnectedService; using Microsoft.OData.ConnectedService.Views; using Microsoft.VisualStudio.ConnectedServices; using Microsoft.VisualStudio.Shell; -using Microsoft.OData.CodeGen; -using Microsoft.OData.CodeGen.Common; -using Microsoft.OData.CodeGen.Models; using Xunit; namespace ODataConnectedService.Tests { - public sealed class ODataConnectedServiceWizardTests: IDisposable + public sealed class ODataConnectedServiceWizardTests : IDisposable { readonly UserSettings initialSettings; readonly string MetadataPath = Path.GetFullPath("TestMetadataCsdl.xml"); @@ -72,6 +71,7 @@ private ServiceConfigurationV4 GetTestConfig() EnableNamingAlias = true, OpenGeneratedFilesInIDE = true, MakeTypesInternal = true, + NoTimestamp = true, IgnoreUnexpectedElementsAndAttributes = true, IncludeT4File = true, ExcludedOperationImports = new List() @@ -263,6 +263,7 @@ public void TestConstructor_ShouldUseDefaultSettingsWhenNotUpdating() Assert.False(advancedPage.UserSettings.GenerateMultipleFiles); Assert.True(advancedPage.UserSettings.IgnoreUnexpectedElementsAndAttributes); Assert.False(advancedPage.UserSettings.MakeTypesInternal); + Assert.False(advancedPage.UserSettings.NoTimestamp); } } @@ -287,7 +288,7 @@ public void TestConstructor_LoadsSavedConfigWhenUpdating() Assert.Equal("http://localhost:8080", endpointPage.UserSettings.WebProxyHost); Assert.True(endpointPage.UserSettings.IncludeWebProxyNetworkCredentials); Assert.True(endpointPage.UserSettings.StoreWebProxyNetworkCredentials); - Assert.Equal("domain", endpointPage.UserSettings.WebProxyNetworkCredentialsDomain); + Assert.Equal("domain", endpointPage.UserSettings.WebProxyNetworkCredentialsDomain); // username and password are not restored from the config Assert.Equal("username", endpointPage.UserSettings.WebProxyNetworkCredentialsUsername); Assert.Equal("password", endpointPage.UserSettings.WebProxyNetworkCredentialsPassword); @@ -427,6 +428,7 @@ public void TestConstructor_LoadsSavedConfigWhenUpdating() Assert.True(advancedPage.UserSettings.GenerateMultipleFiles); Assert.True(advancedPage.UserSettings.IgnoreUnexpectedElementsAndAttributes); Assert.True(advancedPage.UserSettings.MakeTypesInternal); + Assert.True(advancedPage.UserSettings.NoTimestamp); } } @@ -457,6 +459,7 @@ public void TestDisableReadOnlyFieldsWhenUpdating() var advancedView = advancedPage.View as AdvancedSettings; Assert.False(advancedView.IncludeT4File.IsEnabled); Assert.False(advancedView.GenerateMultipleFiles.IsEnabled); + Assert.False(advancedView.NoTimestamp.IsEnabled); } } @@ -464,7 +467,7 @@ public void TestDisableReadOnlyFieldsWhenUpdating() public void TestGetFinishedServiceInstanceAsync_SavesUserSettingsAndReturnsServiceInstanceWithConfigFromTheWizard() { var context = new TestConnectedServiceProviderContext(false); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.UserSettings.ServiceName = "TestService"; @@ -473,7 +476,7 @@ public void TestGetFinishedServiceInstanceAsync_SavesUserSettingsAndReturnsServi endpointPage.UserSettings.IncludeCustomHeaders = true; endpointPage.UserSettings.StoreCustomHttpHeaders = true; endpointPage.UserSettings.CustomHttpHeaders = "Key:val"; - endpointPage.UserSettings.IncludeWebProxy = true; + endpointPage.UserSettings.IncludeWebProxy = true; endpointPage.UserSettings.WebProxyHost = "http://localhost:8080"; endpointPage.UserSettings.IncludeWebProxyNetworkCredentials = true; endpointPage.UserSettings.StoreWebProxyNetworkCredentials = true; @@ -531,6 +534,7 @@ public void TestGetFinishedServiceInstanceAsync_SavesUserSettingsAndReturnsServi advancedPage.UserSettings.IncludeT4File = true; advancedPage.UserSettings.GenerateMultipleFiles = true; advancedPage.UserSettings.OpenGeneratedFilesInIDE = true; + advancedPage.UserSettings.NoTimestamp = true; operationsPage.OnPageLeavingAsync(new WizardLeavingArgs(typesPage)).Wait(); typesPage.OnPageLeavingAsync(new WizardLeavingArgs(advancedPage)).Wait(); @@ -613,6 +617,7 @@ public void TestGetFinishedServiceInstanceAsync_SavesUserSettingsAndReturnsServi Assert.True(config.IncludeT4File); Assert.True(config.GenerateMultipleFiles); Assert.True(config.OpenGeneratedFilesInIDE); + Assert.True(config.NoTimestamp); } } @@ -622,7 +627,7 @@ public void GetFinishedServiceInstanceAsync_WhenUpdating_ShouldUseSavedConfigWhe var savedConfig = GetTestConfig(); savedConfig.Endpoint = MetadataPath; var context = new TestConnectedServiceProviderContext(true, savedConfig); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -671,6 +676,7 @@ public void GetFinishedServiceInstanceAsync_WhenUpdating_ShouldUseSavedConfigWhe Assert.True(config.IncludeT4File); Assert.True(config.GenerateMultipleFiles); Assert.True(config.OpenGeneratedFilesInIDE); + Assert.True(config.NoTimestamp); } } @@ -678,7 +684,7 @@ public void GetFinishedServiceInstanceAsync_WhenUpdating_ShouldUseSavedConfigWhe public void ShouldPreserveState_WhenMovingBetweenPagesAndBack() { var context = new TestConnectedServiceProviderContext(); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -721,6 +727,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack() advancedPage.UserSettings.UseDataServiceCollection = true; advancedPage.UserSettings.MakeTypesInternal = true; advancedPage.UserSettings.UseNamespacePrefix = true; + advancedPage.UserSettings.NoTimestamp = true; advancedPage.OnPageLeavingAsync(null).Wait(); endpointPage.OnPageEnteringAsync(null).Wait(); @@ -737,6 +744,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack() Assert.True(advancedPage.UserSettings.UseNamespacePrefix); Assert.True(advancedPage.UserSettings.UseDataServiceCollection); Assert.True(advancedPage.UserSettings.MakeTypesInternal); + Assert.True(advancedPage.UserSettings.NoTimestamp); advancedPage.UserSettings.NamespacePrefix = "MyNamespace"; advancedPage.UserSettings.GenerateMultipleFiles = true; advancedPage.UserSettings.UseDataServiceCollection = false; @@ -773,6 +781,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack() Assert.Equal("A:b", config.CustomHttpHeaders); Assert.True(config.GenerateMultipleFiles); Assert.True(config.MakeTypesInternal); + Assert.True(config.NoTimestamp); Assert.True(config.UseNamespacePrefix); Assert.Equal("MyNamespace", config.NamespacePrefix); Assert.False(config.UseDataServiceCollection); @@ -798,7 +807,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack_WhenUpdating() var savedConfig = GetTestConfig(); savedConfig.Endpoint = MetadataPath; var context = new TestConnectedServiceProviderContext(true, savedConfig); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -828,6 +837,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack_WhenUpdating() advancedPage.UserSettings.UseDataServiceCollection = true; advancedPage.UserSettings.MakeTypesInternal = true; advancedPage.UserSettings.UseNamespacePrefix = true; + advancedPage.UserSettings.NoTimestamp = true; advancedPage.OnPageLeavingAsync(null).Wait(); endpointPage.OnPageEnteringAsync(null).Wait(); @@ -841,6 +851,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack_WhenUpdating() Assert.True(advancedPage.UserSettings.UseNamespacePrefix); Assert.True(advancedPage.UserSettings.UseDataServiceCollection); Assert.True(advancedPage.UserSettings.MakeTypesInternal); + Assert.True(advancedPage.UserSettings.NoTimestamp); advancedPage.UserSettings.NamespacePrefix = "MyNamespace"; advancedPage.UserSettings.GenerateMultipleFiles = true; advancedPage.UserSettings.UseDataServiceCollection = false; @@ -876,6 +887,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack_WhenUpdating() Assert.Equal("A:b", config.CustomHttpHeaders); Assert.True(config.GenerateMultipleFiles); Assert.True(config.MakeTypesInternal); + Assert.True(config.NoTimestamp); Assert.True(config.UseNamespacePrefix); Assert.Equal("MyNamespace", config.NamespacePrefix); Assert.False(config.UseDataServiceCollection); @@ -906,7 +918,7 @@ public void ShouldPreserveState_WhenMovingBetweenPagesAndBack_WhenUpdating() public void ShouldReloadOperationsAndTypesForNewEndpoint_WhenEndpointIsChangedBeforeFinishing() { var context = new TestConnectedServiceProviderContext(); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -970,7 +982,7 @@ public void ShouldReloadOperationsAndTypesForNewEndpoint_WhenEndpointIsChangedBe public void ShouldDeselectOperations_WhenRelatedTypeIsDeselectedBefore() { var context = new TestConnectedServiceProviderContext(); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -1004,7 +1016,7 @@ public void ShouldDeselectOperations_WhenRelatedTypeIsDeselectedBefore() public void ShouldDeselectBoundOperations_WhenRelatedTypeIsDeselectedBefore() { var context = new TestConnectedServiceProviderContext(); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.OnPageEnteringAsync(null).Wait(); @@ -1046,7 +1058,7 @@ public void ShouldDeselectBoundOperations_WhenRelatedTypeIsDeselectedBefore() public void UnsupportedFeaturesAreDisabledOrHidden_WhenServiceIsV3OrLess() { var context = new TestConnectedServiceProviderContext(); - using(var wizard = new ODataConnectedServiceWizard(context)) + using (var wizard = new ODataConnectedServiceWizard(context)) { var endpointPage = wizard.ConfigODataEndpointViewModel; endpointPage.UserSettings.Endpoint = MetadataPathV3; @@ -1080,7 +1092,7 @@ public int GetHashCode(OperationImportModel obj) } } - internal class TestConnectedServiceProviderContext: ConnectedServiceProviderContext + internal class TestConnectedServiceProviderContext : ConnectedServiceProviderContext { ServiceConfigurationV4 savedData; diff --git a/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTest.cs b/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTest.cs index 14624ef2..3cc1b4a4 100644 --- a/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTest.cs +++ b/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTest.cs @@ -5,8 +5,8 @@ // //--------------------------------------------------------------------------------- -using Microsoft.VisualStudio.TestTools.UnitTesting; using Microsoft.OData.CodeGen.Templates; +using Microsoft.VisualStudio.TestTools.UnitTesting; using ODataConnectedService.Tests.TestHelpers; namespace Microsoft.OData.ConnectedService.Tests.Templates @@ -15,7 +15,7 @@ namespace Microsoft.OData.ConnectedService.Tests.Templates public class ODataT4CodeGeneratorTest { - + [TestMethod] public void TestEntitiesComplexTypesEnumsFunctions() { @@ -61,6 +61,22 @@ public void TestEntitiesComplexTypesEnumFunctionsWithInternalTypes() GeneratedCodeHelpers.VerifyGeneratedCode(expected, output); } + + [TestMethod] + public void TestEntitiesComplexTypesEnumFunctionsWithNoTimestamp() + { + string edmx = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctions.xml"); + string expected = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctions.cs"); + var generator = new ODataT4CodeGenerator() + { + Edmx = edmx, + TargetLanguage = ODataT4CodeGenerator.LanguageOption.CSharp, + NoTimestamp = true, + }; + var output = generator.TransformText(); + GeneratedCodeHelpers.VerifyGeneratedCodeNoTimestamp(expected, output); + } + [TestMethod] public void TestEntitiesComplexTypesEnumFunctionsDSCWithInternalTypes() { @@ -78,6 +94,38 @@ public void TestEntitiesComplexTypesEnumFunctionsDSCWithInternalTypes() GeneratedCodeHelpers.VerifyGeneratedCode(expected, output); } + [TestMethod] + public void TestEntitiesComplexTypesEnumFunctionsDSCWithNoTimestamp() + { + string edmx = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctions.xml"); + string expected = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctionsDSC.cs"); + var generator = new ODataT4CodeGenerator() + { + Edmx = edmx, + TargetLanguage = ODataT4CodeGenerator.LanguageOption.CSharp, + UseDataServiceCollection = true, + NoTimestamp = true, + }; + var output = generator.TransformText(); + GeneratedCodeHelpers.VerifyGeneratedCodeNoTimestamp(expected, output); + } + [TestMethod] + public void TestEntitiesComplexTypesEnumFunctionsDSCWithInternalTypesWithNoTimestamp() + { + string edmx = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctions.xml"); + string expected = GeneratedCodeHelpers.LoadReferenceContent("EntitiesEnumsFunctionsDSCWithInternalTypes.cs"); + var generator = new ODataT4CodeGenerator() + { + Edmx = edmx, + TargetLanguage = ODataT4CodeGenerator.LanguageOption.CSharp, + UseDataServiceCollection = true, + MakeTypesInternal = true, + NoTimestamp = true, + }; + var output = generator.TransformText(); + GeneratedCodeHelpers.VerifyGeneratedCodeNoTimestamp(expected, output); + } + [TestMethod] public void TestTypeDefinitionsParamsConvertedToUnderlyingType() { diff --git a/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTests.cs b/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTests.cs index 60882fe3..ff58f9ff 100644 --- a/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTests.cs +++ b/test/ODataConnectedService.Tests/Templates/ODataT4CodeGeneratorTests.cs @@ -5,33 +5,22 @@ // //--------------------------------------------------------------------------------- -using FluentAssertions; -using Microsoft.CSharp; -using Microsoft.OData.Edm; -using Microsoft.Spatial; -using Microsoft.VisualBasic; -using Microsoft.VisualStudio.TestTools.UnitTesting; using System; -using System.CodeDom.Compiler; -using System.ComponentModel; +using System.Collections.Generic; using System.Diagnostics; +using System.Globalization; using System.IO; -using System.Linq; +using System.Net; +using System.Reflection; +using System.Text.RegularExpressions; using System.Xml; +using FluentAssertions; +using Microsoft.OData.CodeGen.Templates; +using Microsoft.VisualStudio.TestTools.UnitTesting; +using ODataConnectedService.Tests.TestHelpers; namespace ODataConnectedService.Tests { - using System.Reflection; - using Microsoft.OData; - using System.Text.RegularExpressions; - using Microsoft.OData.CodeGen.Templates; - using Microsoft.OData.Client; - using System.Collections.Generic; - using System.Net; - using ODataConnectedService.Tests.TestHelpers; - using System.Globalization; - using System.ComponentModel.DataAnnotations; - [TestClass] public class ODataT4CodeGeneratorTests { @@ -90,7 +79,7 @@ public void Init() { T4TransformToolPath = T4TransformToolPathVSVer2017Community; } - else if(File.Exists(T4TransformToolPathVer11)) + else if (File.Exists(T4TransformToolPathVer11)) { T4TransformToolPath = T4TransformToolPathVer11; } @@ -186,7 +175,7 @@ public void CodeGenMaxLengthEdmx() [TestMethod] public void CodeGenSimpleEdmxMultipleFiles() { - string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.SimpleMultipleFiles.Metadata, null, true, false, generateMultipleFiles : true); + string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.SimpleMultipleFiles.Metadata, null, true, false, generateMultipleFiles: true); string expectedTestType = GeneratedCodeHelpers.NormalizeGeneratedCode(ODataT4CodeGeneratorTestDescriptors.GetFileContent("SimpleMultipleTestType.cs")); string actualTestType = GeneratedCodeHelpers.NormalizeGeneratedCode(File.ReadAllText(Path.Combine(Path.GetTempPath(), "TestType.cs"))); @@ -405,7 +394,7 @@ public void CodeGenWithMultiReferenceModel() [TestMethod] public void CodeGenWithMultiReferenceModelRelativeUri() { - string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.MultiReferenceModelRelativeUri.Metadata, null, true, false, metadataDocumentUri: ODataT4CodeGeneratorTestDescriptors.EdmxWithMultiReferenceModelRelativeUriFilePath ); + string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.MultiReferenceModelRelativeUri.Metadata, null, true, false, metadataDocumentUri: ODataT4CodeGeneratorTestDescriptors.EdmxWithMultiReferenceModelRelativeUriFilePath); ODataT4CodeGeneratorTestDescriptors.MultiReferenceModelRelativeUri.Verify(code, true /*isCSharp*/, false /*useDSC*/); code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.MultiReferenceModelRelativeUri.Metadata, null, false, false, metadataDocumentUri: ODataT4CodeGeneratorTestDescriptors.EdmxWithMultiReferenceModelRelativeUriFilePath); @@ -590,7 +579,7 @@ public void CodeGenSelectingSchemaTypesTest() $"{@namespace}PublicTransportation" }; - string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.EntitiesEnumsFunctionsSelectTypes.Metadata, null, true, false, false, false, null, true,excludedSchemaTypes : excludedSchemaTypes); + string code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.EntitiesEnumsFunctionsSelectTypes.Metadata, null, true, false, false, false, null, true, excludedSchemaTypes: excludedSchemaTypes); ODataT4CodeGeneratorTestDescriptors.EntitiesEnumsFunctionsSelectTypes.Verify(code, true/*isCSharp*/, false/*useDSC*/); code = CodeGenWithT4Template(ODataT4CodeGeneratorTestDescriptors.EntitiesEnumsFunctionsSelectTypes.Metadata, null, false/*isCSharp*/, false, false, false, null, true, excludedSchemaTypes: excludedSchemaTypes); @@ -676,9 +665,8 @@ private static string CodeGenWithT4Template(string edmx, string namespacePrefix, bool useDataServiceCollection, bool enableNamingAlias = false, bool ignoreUnexpectedElementsAndAttributes = false, Func, XmlReader> getReferencedModelReaderFunc = null, - bool appendDSCSuffix = false, string MetadataFilePath = null, bool generateMultipleFiles = false, string metadataDocumentUri = null, - IEnumerable excludedSchemaTypes = default(List)) - + bool appendDSCSuffix = false, string MetadataFilePath = null, bool generateMultipleFiles = false, bool noTimestamp = false, + string metadataDocumentUri = null, IEnumerable excludedSchemaTypes = default(List)) { if (useDataServiceCollection && appendDSCSuffix) // hack now @@ -703,6 +691,7 @@ private static string CodeGenWithT4Template(string edmx, string namespacePrefix, EnableNamingAlias = enableNamingAlias, IgnoreUnexpectedElementsAndAttributes = ignoreUnexpectedElementsAndAttributes, GenerateMultipleFiles = generateMultipleFiles, + NoTimestamp = noTimestamp, ExcludedSchemaTypes = excludedSchemaTypes }; @@ -779,7 +768,7 @@ public static string Execute(string filename, string arguments, int? expectedExi Assert.IsNotNull(filename, "null filename"); Assert.IsTrue(File.Exists(filename) && !Directory.Exists(filename), "missing file: {0}", filename); - using(var process = new Process()) + using (var process = new Process()) { process.StartInfo.FileName = filename; process.StartInfo.Arguments = arguments; diff --git a/test/ODataConnectedService.Tests/TestHelpers/GeneratedCodeHelpers.cs b/test/ODataConnectedService.Tests/TestHelpers/GeneratedCodeHelpers.cs index b6238769..c0df61f9 100644 --- a/test/ODataConnectedService.Tests/TestHelpers/GeneratedCodeHelpers.cs +++ b/test/ODataConnectedService.Tests/TestHelpers/GeneratedCodeHelpers.cs @@ -5,21 +5,21 @@ // //--------------------------------------------------------------------------------- -using Microsoft.CSharp; -using Microsoft.OData.Edm; -using Microsoft.OData; -using Microsoft.Spatial; -using Microsoft.VisualBasic; -using Microsoft.VisualStudio.TestTools.UnitTesting; using System; using System.CodeDom.Compiler; +using System.ComponentModel.DataAnnotations; +using System.Data.Services.Client; using System.IO; using System.Reflection; using System.Text.RegularExpressions; -using System.Data.Services.Client; -using System.ComponentModel.DataAnnotations; -using Microsoft.OData.CodeGen.Templates; using FluentAssertions; +using Microsoft.CSharp; +using Microsoft.OData; +using Microsoft.OData.CodeGen.Templates; +using Microsoft.OData.Edm; +using Microsoft.Spatial; +using Microsoft.VisualBasic; +using Microsoft.VisualStudio.TestTools.UnitTesting; namespace ODataConnectedService.Tests.TestHelpers { @@ -69,6 +69,31 @@ public static string NormalizeGeneratedCode(string code) return normalized; } + public static void VerifyGeneratedCodeNoTimestamp(string expectedCode, string actualCode) + { + var normalizedExpected = NormalizeGeneratedCode(expectedCode); + var normalizedActual = NormalizeGeneratedCodeKeepGenerationDate(actualCode); + Assert.AreEqual(normalizedExpected, normalizedActual); + + var normalizedActualWithoutTimestamp = NormalizeGeneratedCode(actualCode); + Assert.AreEqual(normalizedActualWithoutTimestamp, normalizedActual); + } + + public static string NormalizeGeneratedCodeKeepGenerationDate(string code) + { + var normalized = Regex.Replace(code, "// Runtime Version:.*", string.Empty, RegexOptions.Multiline); + normalized = Regex.Replace(normalized, "' Runtime Version:.*", string.Empty, RegexOptions.Multiline); + normalized = Regex.Replace(normalized, + "global::System.CodeDom.Compiler.GeneratedCodeAttribute\\(.*\\)", + "global::System.CodeDom.Compiler.GeneratedCodeAttribute(\"Microsoft.OData.Client.Design.T4\", \"" + T4Version + "\")", + RegexOptions.Multiline); + + //Remove the spaces from the string to avoid indentation change errors + normalized = Regex.Replace(normalized, @"\s+", ""); + + return normalized; + } + public static void VerifyGeneratedCodeCompiles(string source, bool isCSharp) { var results = CompileCode(source, isCSharp); diff --git a/test/ODataConnectedService.Tests/Views/UserSettingsTest.cs b/test/ODataConnectedService.Tests/Views/UserSettingsTest.cs index 38763ad8..1ab69177 100644 --- a/test/ODataConnectedService.Tests/Views/UserSettingsTest.cs +++ b/test/ODataConnectedService.Tests/Views/UserSettingsTest.cs @@ -32,6 +32,7 @@ public void SaveSettingsWhenSaveMethodIsCalled() userSettings.GeneratedFileNamePrefix = "MyPrefix"; userSettings.GenerateMultipleFiles = true; userSettings.MakeTypesInternal = true; + userSettings.NoTimestamp = true; // Save settings userSettings.Save(); @@ -43,6 +44,7 @@ public void SaveSettingsWhenSaveMethodIsCalled() Assert.Equal("MyPrefix", settings.GeneratedFileNamePrefix); Assert.True(settings.GenerateMultipleFiles); Assert.True(settings.MakeTypesInternal); + Assert.True(settings.NoTimestamp); } [Fact] @@ -65,7 +67,7 @@ public void AddToTopOfMruList_ShouldAddToTopWithoutDuplicatingOrExceedingMax() // Add an endpoint. userSettings.AddMruEndpoint(endpoint1); - Assert.Single(userSettings.MruEndpoints); + Assert.Single(userSettings.MruEndpoints); // Add another endpoint.The latest endpoint to be added is at the top of the MruList. userSettings.AddMruEndpoint(endpoint2);