mirror of
				https://github.com/OpenAPITools/openapi-generator.git
				synced 2025-10-24 21:33:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html><html lang="en"><head><meta charSet="utf-8"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><title>Debugging · OpenAPI Generator</title><meta name="viewport" content="width=device-width"/><meta name="generator" content="Docusaurus"/><meta name="description" content="## Templates"/><meta name="docsearch:language" content="en"/><meta property="og:title" content="Debugging · OpenAPI Generator"/><meta property="og:type" content="website"/><meta property="og:url" content="https://openapi-generator.tech/"/><meta property="og:description" content="## Templates"/><meta property="og:image" content="https://openapi-generator.tech/img/docusaurus.png"/><meta name="twitter:card" content="summary"/><meta name="twitter:image" content="https://openapi-generator.tech/img/icons/twitter.svg"/><link rel="shortcut icon" href="/img/favicon.png"/><link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/default.min.css"/><link rel="alternate" type="application/atom+xml" href="https://openapi-generator.tech/blog/atom.xml" title="OpenAPI Generator Blog ATOM Feed"/><link rel="alternate" type="application/rss+xml" href="https://openapi-generator.tech/blog/feed.xml" title="OpenAPI Generator Blog RSS Feed"/><script>
 | ||
|               (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
 | ||
|               (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
 | ||
|               m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
 | ||
|               })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
 | ||
| 
 | ||
|               ga('create', 'UA-132927057-1', 'auto');
 | ||
|               ga('send', 'pageview');
 | ||
|             </script><script type="text/javascript" src="https://buttons.github.io/buttons.js"></script><script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.0/clipboard.min.js"></script><script type="text/javascript" src="/js/code-block-buttons.js"></script><script src="https://unpkg.com/vanilla-back-to-top@7.1.14/dist/vanilla-back-to-top.min.js"></script><script>
 | ||
|         document.addEventListener('DOMContentLoaded', function() {
 | ||
|           addBackToTop(
 | ||
|             {"zIndex":100}
 | ||
|           )
 | ||
|         });
 | ||
|         </script><script src="/js/scrollSpy.js"></script><link rel="stylesheet" href="/css/main.css"/><script src="/js/codetabs.js"></script></head><body class="sideNavVisible separateOnPageNav"><div class="fixedHeaderContainer"><div class="headerWrapper wrapper"><header><a href="/"><img class="logo" src="/img/mono-logo.svg" alt="OpenAPI Generator"/><h2 class="headerTitleWithLogo">OpenAPI Generator</h2></a><div class="navigationWrapper navigationSlider"><nav class="slidingNav"><ul class="nav-site nav-site-internal"><li class="siteNavGroupActive"><a href="/docs/installation" target="_self">Get Started</a></li><li class="siteNavGroupActive"><a href="/docs/generators" target="_self">Generators</a></li><li class="siteNavGroupActive"><a href="/docs/roadmap" target="_self">Roadmap</a></li><li class=""><a href="/team" target="_self">Team</a></li><li class=""><a href="/docs/faq" target="_self">FAQ</a></li><li class=""><a href="/blog/" target="_self">Blog</a></li></ul></nav></div></header></div></div><div class="navPusher"><div class="docMainWrapper wrapper"><div class="docsNavContainer" id="docsNav"><nav class="toc"><div class="toggleNav"><section class="navWrapper wrapper"><div class="navBreadcrumb wrapper"><div class="navToggle" id="navToggler"><div class="hamburger-menu"><div class="line1"></div><div class="line2"></div><div class="line3"></div></div></div><h2><i>›</i><span>Extending</span></h2><div class="tocToggler" id="tocToggler"><i class="icon-toc"></i></div></div><div class="navGroups"><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Getting Started<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/installation">CLI Installation</a></li><li class="navListItem"><a class="navItem" href="/docs/plugins">Plugins</a></li><li class="navListItem"><a class="navItem" href="/docs/online">Online</a></li><li class="navListItem"><a class="navItem" href="/docs/usage">Usage</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Extending<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/templating">Using Templates</a></li><li class="navListItem"><a class="navItem" href="/docs/customization">Customization</a></li><li class="navListItem navListItemActive"><a class="navItem" href="/docs/debugging">Debugging</a></li><li class="navListItem"><a class="navItem" href="/docs/integrations">Workflow Integrations</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Contributing<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/contributing">Guidelines</a></li><li class="navListItem"><a class="navItem" href="/docs/code-of-conduct">Code of Conduct</a></li><li class="navListItem"><a class="navItem" href="/docs/contribute-building">Building the code</a></li><li class="navListItem"><a class="navItem" href="/docs/new-generator">Create a New Generator</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">About<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/roadmap">Roadmap</a></li><li class="navListItem"><a class="navItem" href="/docs/swagger-codegen-migration">Migrating from Swagger Codegen</a></li><li class="navListItem"><a class="navItem" href="/docs/fork-qna">Swagger Codegen Fork: Q&A</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">Releases<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/release-summary">Release Summary</a></li><li class="navListItem"><a class="navItem" href="/docs/release-3-0-0">Release Notes: 3.0.0</a></li></ul></div><div class="navGroup"><h3 class="navGroupCategoryTitle collapsible">API<span class="arrow"><svg width="24" height="24" viewBox="0 0 24 24"><path fill="#565656" d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"></path><path d="M0 0h24v24H0z" fill="none"></path></svg></span></h3><ul class="hide"><li class="navListItem"><a class="navItem" href="/docs/generators">Generators List</a></li></ul></div></div></section></div><script>
 | ||
|             var coll = document.getElementsByClassName('collapsible');
 | ||
|             var checkActiveCategory = true;
 | ||
|             for (var i = 0; i < coll.length; i++) {
 | ||
|               var links = coll[i].nextElementSibling.getElementsByTagName('*');
 | ||
|               if (checkActiveCategory){
 | ||
|                 for (var j = 0; j < links.length; j++) {
 | ||
|                   if (links[j].classList.contains('navListItemActive')){
 | ||
|                     coll[i].nextElementSibling.classList.toggle('hide');
 | ||
|                     coll[i].childNodes[1].classList.toggle('rotate');
 | ||
|                     checkActiveCategory = false;
 | ||
|                     break;
 | ||
|                   }
 | ||
|                 }
 | ||
|               }
 | ||
| 
 | ||
|               coll[i].addEventListener('click', function() {
 | ||
|                 var arrow = this.childNodes[1];
 | ||
|                 arrow.classList.toggle('rotate');
 | ||
|                 var content = this.nextElementSibling;
 | ||
|                 content.classList.toggle('hide');
 | ||
|               });
 | ||
|             }
 | ||
| 
 | ||
|             document.addEventListener('DOMContentLoaded', function() {
 | ||
|               createToggler('#navToggler', '#docsNav', 'docsSliderActive');
 | ||
|               createToggler('#tocToggler', 'body', 'tocActive');
 | ||
| 
 | ||
|               var headings = document.querySelector('.toc-headings');
 | ||
|               headings && headings.addEventListener('click', function(event) {
 | ||
|                 var el = event.target;
 | ||
|                 while(el !== headings){
 | ||
|                   if (el.tagName === 'A') {
 | ||
|                     document.body.classList.remove('tocActive');
 | ||
|                     break;
 | ||
|                   } else{
 | ||
|                     el = el.parentNode;
 | ||
|                   }
 | ||
|                 }
 | ||
|               }, false);
 | ||
| 
 | ||
|               function createToggler(togglerSelector, targetSelector, className) {
 | ||
|                 var toggler = document.querySelector(togglerSelector);
 | ||
|                 var target = document.querySelector(targetSelector);
 | ||
| 
 | ||
|                 if (!toggler) {
 | ||
|                   return;
 | ||
|                 }
 | ||
| 
 | ||
|                 toggler.onclick = function(event) {
 | ||
|                   event.preventDefault();
 | ||
| 
 | ||
|                   target.classList.toggle(className);
 | ||
|                 };
 | ||
|               }
 | ||
|             });
 | ||
|         </script></nav></div><div class="container mainContainer"><div class="wrapper"><div class="post"><header class="postHeader"><h1 class="postHeaderTitle">Debugging</h1></header><article><div><span><h2><a class="anchor" aria-hidden="true" id="templates"></a><a href="#templates" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Templates</h2>
 | ||
| <p>Sometimes, you may have issues with variables in your templates. As discussed in the <a href="/docs/templating">templating</a> docs, we offer a variety of system properties for inspecting the models bound to templates.</p>
 | ||
| <dl>
 | ||
| <dt><code>-DdebugOpenAPI</code></dt>
 | ||
| <dd>Prints out the JSON model of the OpenAPI Document, as seen by OpenAPI Generator</dd>
 | ||
| <dt><code>-DdebugModels</code></dt>
 | ||
| <dd>Prints out the JSON model passed to model templates</dd>
 | ||
| <dt><code>-DdebugOperations</code></dt>
 | ||
| <dd>Prints out the JSON model passed to operation (api) templates</dd>
 | ||
| <dt><code>-DdebugSupportingFiles</code></dt>
 | ||
| <dd>Prints out the JSON model passed to supporting files</dd>
 | ||
| </dl>
 | ||
| <p>One or more of these properties can be passed alongside other command line options:</p>
 | ||
| <pre><code class="hljs css language-bash">openapi-generator generate -g go \
 | ||
|     -o out \
 | ||
|     -i petstore-minimal.yaml \
 | ||
|     -DdebugModels \
 | ||
|     -DdebugOperations
 | ||
| </code></pre>
 | ||
| <p>Or you can add these to your <code>JAVA_OPTS</code> environment variable (this applies to every invocation of the tool):</p>
 | ||
| <pre><code class="hljs css language-bash"><span class="hljs-built_in">export</span> JAVA_OPTS=<span class="hljs-string">"<span class="hljs-variable">${JAVA_OPTS}</span> -DdebugModels -DdebugOperations"</span>
 | ||
| </code></pre>
 | ||
| <blockquote>
 | ||
| <p>NOTE: Globally available system options like these will apply to all invocations of the generator (CLI and plugins)</p>
 | ||
| </blockquote>
 | ||
| <h2><a class="anchor" aria-hidden="true" id="runtime"></a><a href="#runtime" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Runtime</h2>
 | ||
| <p>When you're working with a custom generator, a new generator, or otherwise trying to understand the behavior of the toolset, you may need to attach a remote debugger in order to step through the code.</p>
 | ||
| <p>The steps are shown here for a specific version of the generator, but apply the same if you're working off master or a feature branch.</p>
 | ||
| <ul>
 | ||
| <li>Determine the version of <code>openapi-generator</code> you're using. For the CLI, this is:
 | ||
| <pre><code class="hljs">openapi-generator <span class="hljs-built_in">version</span>
 | ||
| </code></pre></li>
 | ||
| <li>Navigate to the <code>openapi-generator</code> source directory (see <a href="/docs/contribute-building">building</a> docs for obtaining source code and brief introduction).</li>
 | ||
| <li>Checkout the branch/tag for the target version. Branches are not prefixed, but tags are prefixed with a <code>v</code>. For instance if you're using version <code>3.3.0</code>, you will execute:
 | ||
| <pre><code class="hljs">git checkout v3<span class="hljs-number">.3</span><span class="hljs-number">.0</span>
 | ||
| </code></pre></li>
 | ||
| <li>Open the project in your IDE.</li>
 | ||
| <li>Setup your IDE for remote debugging. You'll want to define a port used for connecting the remote debugger. For this example, we'll use <code>5005</code>. See external tutorials for <a href="https://www.jetbrains.com/help/idea/run-debug-configuration-remote-debug.html">IntelliJ</a> and <a href="https://www.ibm.com/developerworks/library/os-eclipse-javadebug/index.html">Eclipse</a></li>
 | ||
| <li>Export the debug configuration, specifying <code>suspend=y</code> so you have time to attach a remote debugger. These are passed as Java system properties, either on command line or as part of the <code>JAVA_OPTS</code> environment variable. This will look like:
 | ||
| <pre><code class="hljs"><span class="hljs-builtin-name">export</span> <span class="hljs-attribute">JAVA_OPTS</span>=<span class="hljs-string">"<span class="hljs-variable">${JAVA_OPTS}</span> -agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005"</span>
 | ||
| </code></pre></li>
 | ||
| <li>Execute the generator with your desired options. You should see the application output <em>only</em>
 | ||
| <pre><code class="hljs"><span class="hljs-type">Listening</span> for trans<span class="hljs-keyword">port</span> dt_socket at address: 5005
 | ||
| </code></pre></li>
 | ||
| <li>Set breakpoints in code, and then attach your remote debugger from your IDE (see above). The generator will automatically unblock once the remote debugger is attached. You can now step through the code.</li>
 | ||
| </ul>
 | ||
| <h2><a class="anchor" aria-hidden="true" id="logs"></a><a href="#logs" aria-hidden="true" class="hash-link"><svg class="hash-link-icon" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Logs</h2>
 | ||
| <p>You can try to enable debugging log with <code>-Dlog.level=debug</code> option to the <code>JAVA_OPTS</code> environment variable to see more information:</p>
 | ||
| <pre><code class="hljs css language-bash"><span class="hljs-built_in">export</span> JAVA_OPTS=<span class="hljs-string">"<span class="hljs-variable">${JAVA_OPTS}</span> -Dlog.level=debug"</span>
 | ||
| </code></pre>
 | ||
| <p>Set the option then DEBUG logs are printed out:</p>
 | ||
| <pre><code class="hljs css language-bash">openapi-generator generate -g go ...
 | ||
| 
 | ||
| ...
 | ||
| ...
 | ||
| [main] DEBUG o.o.codegen.DefaultCodegen - debugging fromProperty <span class="hljs-keyword">for</span> files : class Schema {
 | ||
|     <span class="hljs-built_in">type</span>: null
 | ||
|     format: null
 | ||
|     <span class="hljs-variable">$ref</span>: <span class="hljs-comment">#/components/schemas/File</span>
 | ||
| ...
 | ||
| ...
 | ||
| </code></pre>
 | ||
| </span></div></article></div><div class="docLastUpdate"><em>Last updated on 2019-11-5</em></div><div class="docs-prevnext"><a class="docs-prev button" href="/docs/customization"><span class="arrow-prev">← </span><span>Customization</span></a><a class="docs-next button" href="/docs/integrations"><span>Workflow Integrations</span><span class="arrow-next"> →</span></a></div></div></div><nav class="onPageNav"><ul class="toc-headings"><li><a href="#templates">Templates</a></li><li><a href="#runtime">Runtime</a></li><li><a href="#logs">Logs</a></li></ul></nav></div><footer class="nav-footer" id="footer"><section class="sitemap"><a href="/" class="nav-home"><img src="/img/mono-logo.svg" alt="OpenAPI Generator" width="66" height="58"/></a><div><h5>Docs</h5><a href="/docs/en/customization.html">Customizing Generators</a><a href="/docs/en/integrations.html">Workflow Integrations</a></div><div><h5>Community</h5><a href="/en/users.html">User Showcase</a><a href="http://stackoverflow.com/questions/tagged/openapi-generator" target="_blank" rel="noreferrer noopener">Stack Overflow</a><a href="https://join.slack.com/t/openapi-generator/shared_invite/enQtNzAyNDMyOTU0OTE1LTY5ZDBiNDI5NzI5ZjQ1Y2E5OWVjMjZkYzY1ZGM2MWQ4YWFjMzcyNDY5MGI4NjQxNDBiMTlmZTc5NjY2ZTQ5MGM">Chat Room</a><a href="https://twitter.com/oas_generator" target="_blank" rel="noreferrer noopener">Twitter</a></div><div><h5>More</h5><a href="/blog">Blog</a><a href="https://github.com/OpenAPITools/openapi-generator">GitHub Repo</a><a class="github-button" href="https://github.com/OpenAPITools/openapi-generator" data-icon="octicon-star" data-count-href="/OpenAPITools/openapi-generator/stargazers" data-show-count="true" data-count-aria-label="# stargazers on GitHub" aria-label="Star this project on GitHub">Star</a></div></section><section class="copyright">Copyright © 2019 OpenAPI-Generator Contributors (https://openapi-generator.tech). (Both "OpenAPI Tools" (https://OpenAPITools.org) and "OpenAPI Generator" are not affiliated with OpenAPI Initiative (OAI))</section></footer></div></body></html> |