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

1.28.0 released artifacts do not work in all-in-one #1275

Closed
pavolloffay opened this issue Mar 15, 2023 · 9 comments · Fixed by #1276
Closed

1.28.0 released artifacts do not work in all-in-one #1275

pavolloffay opened this issue Mar 15, 2023 · 9 comments · Fixed by #1276
Labels

Comments

@pavolloffay
Copy link
Member

What happened?

image

Steps to reproduce

Download https://github.com/jaegertracing/jaeger-ui/releases/download/v1.28.0/assets.tar.gz

Expected behavior

The file structure should match previous release https://github.com/jaegertracing/jaeger-ui/releases/download/v1.27.4/assets.tar.gz

Relevant log output

No response

Screenshot

No response

Additional context

No response

Jaeger backend version

No response

SDK

No response

Pipeline

No response

Stogage backend

No response

Operating system

No response

Deployment model

No response

Deployment configs

No response

@yurishkuro
Copy link
Member

The build system changed, the layout may be different

@pavolloffay
Copy link
Member Author

It seems that all the files in correctly added to the released archive.

Probably something else needs to be changed.

@pavolloffay
Copy link
Member Author

The jaeger-ui-root div is mepty when I run the make run-all-in-one

image

The cd packages/jaeger-ui && yarn start

image

@yurishkuro
Copy link
Member

yep, exactly, it seems yarn start and yarn build are producing different output

cc @mszabo-wikia

@pavolloffay
Copy link
Member Author

I also run vite build and the jaeger-ui-root is still empty.

@pavolloffay
Copy link
Member Author

Actually this is the view source from the make run-all-in-one

  | <!doctype html>
-- | --
  | <html lang="en">
  | <head>
  | <meta charset="utf-8">
  | <meta name="viewport" content="width=device-width, initial-scale=1">
  | <!-- prevent caching of this HTML by any server, Go or otherwise -->
  | <meta http-equiv="cache-control" content="max-age=0" />
  | <meta http-equiv="cache-control" content="no-cache" />
  | <meta http-equiv="expires" content="0" />
  | <meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT" />
  | <meta http-equiv="pragma" content="no-cache" />
  |  
  | <!-- NOTE: The document MUST have a <base> element. package.json#homepage is set to "." as part of resolving https://github.com/jaegertracing/jaeger-ui/issues/42 and therefore static assets are linked via relative URLs. This will break on many document URLs, e.g. /trace/abc, unless a valid base URL is provided. The base href defaults to "/" but the query-service can inject an override. -->
  | <base href="/" data-inject-target="BASE_URL" />
  | <link rel="shortcut icon" href="">
  | <title>Jaeger UI</title>
  | <script>
  | // Jaeger UI config data is embedded by the query-service via search-replace.
  | // This is later merged with defaults into the redux `state.config` via
  | // src/utils/config/get-config.js.
  | // JAEGER_CONFIG_JS
  | // the line above may be replaced by user-provided JS file that should define a UIConfig function.
  | function getJaegerUiConfig() {
  | if(typeof window.UIConfig === 'function') {
  | return UIConfig();
  | }
  | const DEFAULT_CONFIG = null;
  | const JAEGER_CONFIG = DEFAULT_CONFIG;
  | return JAEGER_CONFIG;
  | }
  | // Jaeger version data is embedded by the query-service via search/replace.
  | function getJaegerVersion() {
  | const DEFAULT_VERSION = {"gitCommit":"", "gitVersion":"", "buildDate":""};
  | const JAEGER_VERSION = {"gitCommit":"","gitVersion":"","buildDate":""};
  | return JAEGER_VERSION;
  | }
  |  
  | // Workaround some legacy NPM dependencies that assume this is always defined.
  | window.global = {};
  | // Avoid noise from redux-form until https://github.com/redux-form/redux-form/pull/4723 is released.
  | window.module = {};
  | </script>
  | <script type="module" crossorigin src="./static/index-fd6b4ea3.js"></script>
  | <link rel="stylesheet" href="./static/index-3c2d679b.css">
  | <script type="module">import.meta.url;import("_").catch(()=>1);async function* g(){};window.__vite_is_modern_browser=true;</script>
  | <script type="module">!function(){if(window.__vite_is_modern_browser)return;console.warn("vite: loading legacy chunks, syntax error above and the same error below should be ignored");var e=document.getElementById("vite-legacy-polyfill"),n=document.createElement("script");n.src=e.src,n.onload=function(){System.import(document.getElementById('vite-legacy-entry').getAttribute('data-src'))},document.body.appendChild(n)}();</script>
  | </head>
  | <body>
  | <div id="jaeger-ui-root"></div>
  | <!--
  | This file is the main entry point for the Jaeger UI application.
  | See https://vitejs.dev/guide/#index-html-and-project-root for more information
  | on how asset references are managed by the build system.
  | -->
  |  
  | <script nomodule>!function(){var e=document,t=e.createElement("script");if(!("noModule"in t)&&"onbeforeload"in t){var n=!1;e.addEventListener("beforeload",(function(e){if(e.target===t)n=!0;else if(!e.target.hasAttribute("nomodule")\|\|!n)return;e.preventDefault()}),!0),t.type="module",t.src=".",e.head.appendChild(t),t.remove()}}();</script>
  | <script nomodule crossorigin id="vite-legacy-polyfill" src="./static/polyfills-legacy-9486af1f.js"></script>
  | <script nomodule crossorigin id="vite-legacy-entry" data-src="./static/index-legacy-b69255e2.js">System.import(document.getElementById('vite-legacy-entry').getAttribute('data-src'))</script>
  | </body>
  | </html>
  |  

<!doctype html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- prevent caching of this HTML by any server, Go or otherwise -->
    <meta http-equiv="cache-control" content="max-age=0" />
    <meta http-equiv="cache-control" content="no-cache" />
    <meta http-equiv="expires" content="0" />
    <meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT" />
    <meta http-equiv="pragma" content="no-cache" />

    <!-- NOTE: The document MUST have a <base> element. package.json#homepage is set to "." as part of resolving https://github.com/jaegertracing/jaeger-ui/issues/42 and therefore static assets are linked via relative URLs. This will break on many document URLs, e.g. /trace/abc, unless a valid base URL is provided. The base href defaults to "/" but the query-service can inject an override. -->
    <base href="[/](http://localhost:16686/)" data-inject-target="BASE_URL" />
    <link rel="shortcut icon" href="">
    <title>Jaeger UI</title>
    <script>
      // Jaeger UI config data is embedded by the query-service via search-replace.
      // This is later merged with defaults into the redux `state.config` via
      // src/utils/config/get-config.js.
      // JAEGER_CONFIG_JS
      // the line above may be replaced by user-provided JS file that should define a UIConfig function.
      function getJaegerUiConfig() {
        if(typeof window.UIConfig === 'function') {
          return UIConfig();
        }
        const DEFAULT_CONFIG = null;
        const JAEGER_CONFIG = DEFAULT_CONFIG;
        return JAEGER_CONFIG;
      }
      // Jaeger version data is embedded by the query-service via search/replace.
      function getJaegerVersion() {
        const DEFAULT_VERSION = {"gitCommit":"", "gitVersion":"", "buildDate":""};
        const JAEGER_VERSION = {"gitCommit":"","gitVersion":"","buildDate":""};
        return JAEGER_VERSION;
      }

      // Workaround some legacy NPM dependencies that assume this is always defined.
      window.global = {};
      // Avoid noise from redux-form until https://github.com/redux-form/redux-form/pull/4723 is released.
      window.module = {};
    </script>
    <script type="module" crossorigin src="[./static/index-fd6b4ea3.js](http://localhost:16686/static/index-fd6b4ea3.js)"></script>
    <link rel="stylesheet" href="[./static/index-3c2d679b.css](http://localhost:16686/static/index-3c2d679b.css)">
    <script type="module">import.meta.url;import("_").catch(()=>1);async function* g(){};window.__vite_is_modern_browser=true;</script>
    <script type="module">!function(){if(window.__vite_is_modern_browser)return;console.warn("vite: loading legacy chunks, syntax error above and the same error below should be ignored");var e=document.getElementById("vite-legacy-polyfill"),n=document.createElement("script");n.src=e.src,n.onload=function(){System.import(document.getElementById('vite-legacy-entry').getAttribute('data-src'))},document.body.appendChild(n)}();</script>
  </head>
  <body>
    <div id="jaeger-ui-root"></div>
    <!--
      This file is the main entry point for the Jaeger UI application.
      See https://vitejs.dev/guide/#index-html-and-project-root for more information
      on how asset references are managed by the build system.
    -->
    
    <script nomodule>!function(){var e=document,t=e.createElement("script");if(!("noModule"in t)&&"onbeforeload"in t){var n=!1;e.addEventListener("beforeload",(function(e){if(e.target===t)n=!0;else if(!e.target.hasAttribute("nomodule")||!n)return;e.preventDefault()}),!0),t.type="module",t.src=".",e.head.appendChild(t),t.remove()}}();</script>
    <script nomodule crossorigin id="vite-legacy-polyfill" src="[./static/polyfills-legacy-9486af1f.js](http://localhost:16686/static/polyfills-legacy-9486af1f.js)"></script>
    <script nomodule crossorigin id="vite-legacy-entry" data-src="./static/index-legacy-b69255e2.js">System.import(document.getElementById('vite-legacy-entry').getAttribute('data-src'))</script>
  </body>
</html>

and this from yarn run

  | <!doctype html>
-- | --
  | <html lang="en">
  | <head>
  | <script type="module">
  | import RefreshRuntime from "/@react-refresh"
  | RefreshRuntime.injectIntoGlobalHook(window)
  | window.$RefreshReg$ = () => {}
  | window.$RefreshSig$ = () => (type) => type
  | window.__vite_plugin_react_preamble_installed__ = true
  | </script>
  |  
  | <script type="module" src="/@vite/client"></script>
  |  
  | <meta charset="utf-8">
  | <meta name="viewport" content="width=device-width, initial-scale=1">
  | <!-- prevent caching of this HTML by any server, Go or otherwise -->
  | <meta http-equiv="cache-control" content="max-age=0" />
  | <meta http-equiv="cache-control" content="no-cache" />
  | <meta http-equiv="expires" content="0" />
  | <meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT" />
  | <meta http-equiv="pragma" content="no-cache" />
  |  
  | <!-- NOTE: The document MUST have a <base> element. package.json#homepage is set to "." as part of resolving https://github.com/jaegertracing/jaeger-ui/issues/42 and therefore static assets are linked via relative URLs. This will break on many document URLs, e.g. /trace/abc, unless a valid base URL is provided. The base href defaults to "/" but the query-service can inject an override. -->
  | <base href="/" data-inject-target="BASE_URL" />
  | <link rel="shortcut icon" href="/favicon.ico">
  | <title>Jaeger UI</title>
  | <script>
  | // Jaeger UI config data is embedded by the query-service via search-replace.
  | // This is later merged with defaults into the redux `state.config` via
  | // src/utils/config/get-config.js.
  | // JAEGER_CONFIG_JS
  | // the line above may be replaced by user-provided JS file that should define a UIConfig function.
  | function getJaegerUiConfig() {
  | if(typeof window.UIConfig === 'function') {
  | return UIConfig();
  | }
  | const DEFAULT_CONFIG = null;
  | const JAEGER_CONFIG = DEFAULT_CONFIG;
  | return JAEGER_CONFIG;
  | }
  | // Jaeger version data is embedded by the query-service via search/replace.
  | function getJaegerVersion() {
  | const DEFAULT_VERSION = {"gitCommit":"", "gitVersion":"", "buildDate":""};
  | const JAEGER_VERSION = DEFAULT_VERSION;
  | return JAEGER_VERSION;
  | }
  |  
  | // Workaround some legacy NPM dependencies that assume this is always defined.
  | window.global = {};
  | // Avoid noise from redux-form until https://github.com/redux-form/redux-form/pull/4723 is released.
  | window.module = {};
  | </script>
  | </head>
  | <body>
  | <div id="jaeger-ui-root"></div>
  | <!--
  | This file is the main entry point for the Jaeger UI application.
  | See https://vitejs.dev/guide/#index-html-and-project-root for more information
  | on how asset references are managed by the build system.
  | -->
  | <script type="module" src="/src/index.jsx"></script>
  | </body>
  | </html>
  |  

<!doctype html>
<html lang="en">
  <head>
    <script type="module">
import RefreshRuntime from "/@react-refresh"
RefreshRuntime.injectIntoGlobalHook(window)
window.$RefreshReg$ = () => {}
window.$RefreshSig$ = () => (type) => type
window.__vite_plugin_react_preamble_installed__ = true
</script>

    <script type="module" src="[/@vite/client](http://127.0.0.1:5173/@vite/client)"></script>

    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- prevent caching of this HTML by any server, Go or otherwise -->
    <meta http-equiv="cache-control" content="max-age=0" />
    <meta http-equiv="cache-control" content="no-cache" />
    <meta http-equiv="expires" content="0" />
    <meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT" />
    <meta http-equiv="pragma" content="no-cache" />

    <!-- NOTE: The document MUST have a <base> element. package.json#homepage is set to "." as part of resolving https://github.com/jaegertracing/jaeger-ui/issues/42 and therefore static assets are linked via relative URLs. This will break on many document URLs, e.g. /trace/abc, unless a valid base URL is provided. The base href defaults to "/" but the query-service can inject an override. -->
    <base href="[/](http://127.0.0.1:5173/)" data-inject-target="BASE_URL" />
    <link rel="shortcut icon" href="[/favicon.ico](http://127.0.0.1:5173/favicon.ico)">
    <title>Jaeger UI</title>
    <script>
      // Jaeger UI config data is embedded by the query-service via search-replace.
      // This is later merged with defaults into the redux `state.config` via
      // src/utils/config/get-config.js.
      // JAEGER_CONFIG_JS
      // the line above may be replaced by user-provided JS file that should define a UIConfig function.
      function getJaegerUiConfig() {
        if(typeof window.UIConfig === 'function') {
          return UIConfig();
        }
        const DEFAULT_CONFIG = null;
        const JAEGER_CONFIG = DEFAULT_CONFIG;
        return JAEGER_CONFIG;
      }
      // Jaeger version data is embedded by the query-service via search/replace.
      function getJaegerVersion() {
        const DEFAULT_VERSION = {"gitCommit":"", "gitVersion":"", "buildDate":""};
        const JAEGER_VERSION = DEFAULT_VERSION;
        return JAEGER_VERSION;
      }

      // Workaround some legacy NPM dependencies that assume this is always defined.
      window.global = {};
      // Avoid noise from redux-form until https://github.com/redux-form/redux-form/pull/4723 is released.
      window.module = {};
    </script>
  </head>
  <body>
    <div id="jaeger-ui-root"></div>
    <!--
      This file is the main entry point for the Jaeger UI application.
      See https://vitejs.dev/guide/#index-html-and-project-root for more information
      on how asset references are managed by the build system.
    -->
    <script type="module" src="[/src/index.jsx](http://127.0.0.1:5173/src/index.jsx)"></script>
  </body>
</html>

@yurishkuro
Copy link
Member

I am seeing JS error in the browser console

Uncaught TypeError: Unknown theme type: undefined, name: undefined
    at withSuffix (index-b9997246.js:69:589194)
    at index-b9997246.js:69:590561
    at Array.forEach (<anonymous>)
    at Function.value (index-b9997246.js:69:590521)
    at index-b9997246.js:70:1177
withSuffix @ index-b9997246.js:69
(anonymous) @ index-b9997246.js:69
value @ index-b9997246.js:69
(anonymous) @ index-b9997246.js:70

@yurishkuro
Copy link
Member

@pavolloffay maybe show just the diffs of two HTMLs

@yurishkuro yurishkuro changed the title 1.28.0 released artifacts do not contain static/ jss,media,css 1.28.0 released artifacts do not work in all-in-one Mar 15, 2023
yurishkuro pushed a commit that referenced this issue Mar 15, 2023
## Which problem is this PR solving?
- Unbreak the UI in the production build (closes #1275)
## Short description of the changes
It seems that the antd v3 upgrade in
cda1746 causes an error in the
production build, apparently due to a bad interplay with vite/esbuild
bundling. As a workaround, provide an import alias for the antd icon
sprite file that's causing the issue.[1]

---
[1]
ant-design/ant-design#19002 (comment)

Signed-off-by: Máté Szabó <mszabo@fandom.com>
@yurishkuro
Copy link
Member

I tested #1276 locally with all-in-one, it seems to work fine now.

Katarzyna-B pushed a commit to vervegroup/jaeger-ui that referenced this issue Mar 20, 2023
## Which problem is this PR solving?
- Unbreak the UI in the production build (closes jaegertracing#1275)
## Short description of the changes
It seems that the antd v3 upgrade in
cda1746 causes an error in the
production build, apparently due to a bad interplay with vite/esbuild
bundling. As a workaround, provide an import alias for the antd icon
sprite file that's causing the issue.[1]

---
[1]
ant-design/ant-design#19002 (comment)

Signed-off-by: Máté Szabó <mszabo@fandom.com>
Binrix pushed a commit to Binrix/jaeger-ui that referenced this issue Apr 18, 2023
## Which problem is this PR solving?
- Unbreak the UI in the production build (closes jaegertracing#1275)
## Short description of the changes
It seems that the antd v3 upgrade in
cda1746 causes an error in the
production build, apparently due to a bad interplay with vite/esbuild
bundling. As a workaround, provide an import alias for the antd icon
sprite file that's causing the issue.[1]

---
[1]
ant-design/ant-design#19002 (comment)

Signed-off-by: Máté Szabó <mszabo@fandom.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants