/// <summary>Initializes a new instance of the <see cref="SwaggerToTypeScriptGenerator" /> class.</summary> /// <param name="service">The service.</param> /// <param name="settings">The settings.</param> /// <exception cref="System.ArgumentNullException">service</exception> /// <exception cref="ArgumentNullException"><paramref name="service" /> is <see langword="null" />.</exception> public SwaggerToTypeScriptGenerator(SwaggerService service, SwaggerToTypeScriptGeneratorSettings settings) { if (service == null) throw new ArgumentNullException("service"); Settings = settings; _service = service; foreach (var definition in _service.Definitions) definition.Value.TypeName = definition.Key; _resolver = new TypeScriptTypeResolver(_service.Definitions.Select(p => p.Value).ToArray()); }
/// <summary>Initializes a new instance of the <see cref="SwaggerToTypeScriptGenerator" /> class.</summary> /// <param name="service">The service.</param> /// <param name="settings">The settings.</param> /// <exception cref="System.ArgumentNullException">service</exception> /// <exception cref="ArgumentNullException"><paramref name="service" /> is <see langword="null" />.</exception> public SwaggerToTypeScriptGenerator(SwaggerService service, SwaggerToTypeScriptGeneratorSettings settings) { if (service == null) { throw new ArgumentNullException("service"); } Settings = settings; _service = service; foreach (var definition in _service.Definitions) { definition.Value.TypeName = definition.Key; } _resolver = new TypeScriptTypeResolver(_service.Definitions.Select(p => p.Value).ToArray()); }
public SwaggerToTypeScriptCommand() { Settings = new SwaggerToTypeScriptGeneratorSettings(); }
public void When_parameter_is_array_then_TypeScript_is_correct() { //// Arrange var swagger = @"{ ""swagger"" : ""2.0"", ""info"" : { ""version"" : ""1.0.2"", ""title"" : ""Test API"" }, ""host"" : ""localhost:8080"", ""basePath"" : ""/"", ""tags"" : [ { ""name"" : ""api"" } ], ""schemes"" : [ ""http"" ], ""paths"" : { ""/removeElement"" : { ""delete"" : { ""tags"" : [ ""api"" ], ""summary"" : ""Removes elements"", ""description"" : ""Removes elements"", ""operationId"" : ""removeElement"", ""consumes"" : [ ""application/json"" ], ""produces"" : [ ""application/json"" ], ""parameters"" : [ { ""name"" : ""X-User"", ""in"" : ""header"", ""description"" : ""User identifier"", ""required"" : true, ""type"" : ""string"" }, { ""name"" : ""elementId"", ""in"" : ""query"", ""description"" : ""The ids of existing elements that should be removed"", ""required"" : false, ""type"" : ""array"", ""items"" : { ""type"" : ""integer"", ""format"" : ""int64"" }, } ], ""responses"" : { ""default"" : { ""description"" : ""successful operation"" } } } } }, ""definitions"" : { } } "; var service = SwaggerService.FromJson(swagger); //// Act var settings = new SwaggerToTypeScriptGeneratorSettings { ClassName = "MyClass" }; var generator = new SwaggerToTypeScriptGenerator(service, settings); var code = generator.GenerateFile(); //// Assert Assert.IsTrue(code.Contains(@"elementId.forEach(item => { url += ""elementId="" + encodeURIComponent("""" + item) + ""&""; });")); }