Skip to content
New issue

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

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

Already on GitHub? # to your account

RuntimeError: abort(CompileError: WebAssembly.instantiate(): #152

Closed
avimehenwal opened this issue May 5, 2020 · 24 comments
Closed

RuntimeError: abort(CompileError: WebAssembly.instantiate(): #152

avimehenwal opened this issue May 5, 2020 · 24 comments
Labels
not an issue Asking for help or other discussions

Comments

@avimehenwal
Copy link

avimehenwal commented May 5, 2020

Everytime I try to load d3-graphviz in my vuejs, I get the following console error
and no graph is generated. Can someone please help. My fronted debugging skills are very poor.
d3-@3.0.5

Uncaught (in promise) RuntimeError: abort(CompileError: WebAssembly.instantiate(): expected magic word 00 61 73 6d, found 3c 21 44 4f @+0). Build with -s ASSERTIONS=1 for more info.

Here is my vue component

<template>
  <div>
    <h3>from Component</h3>
    <div id="graph"></div>
  </div>
</template>

<script>
import * as d3 from 'd3';
import 'd3-graphviz';

export default {
  data() {
    return {
      code: 'digraph {a -> b}'
    };
  },
  mounted() {
    console.log(d3.select('#graph').graphviz("#graph").renderDot(this.code))
    d3.select('#graph').graphviz("#graph").renderDot(this.code);
  }
};
</script>

Screenshot from 2020-05-05 13-07-31

@magjac
Copy link
Owner

magjac commented May 5, 2020

I haven't used Vue.js so I cannot say for sure what's wrong, but start by upgrading d3-graphviz to the latest version 3.0.5 and see if it helps. If it doesn't help, please specify how you start your application or even better provide a full test case, including how to build, and start it.

@magjac
Copy link
Owner

magjac commented May 5, 2020

BTW, I think you've accidentally destroyed parts of your comment above by deleting the word graphviz in several places when you edited it.

@avimehenwal
Copy link
Author

avimehenwal commented May 5, 2020

yes, I accidentally selected and replaced graphviz 😢 Thanks for that

Here is the sample code I am trying to run, with instruction to deploy
https://github.com/avimehenwal/graphviz-dot

Component File -> https://github.com/avimehenwal/graphviz-dot/blob/master/src/components/HelloWorld.vue

@magjac
Copy link
Owner

magjac commented May 5, 2020

I don't know how to do it with the development server but this works for the production build:

yarn build
cp -p node_modules/@hpcc-js/wasm/dist/graphvizlib.wasm dist/js
cd dist
http-server .

I did some experimenting with the wasmFolderbased on hpcc-systems/hpcc-js-wasm#26 without any luck. Maybe you can figure it out. Please let me know.

@avimehenwal
Copy link
Author

avimehenwal commented May 5, 2020

Thank you for your comment, surprisingly works for me too in production build 😄
I will update this issue if I find out any leads.
Thankyou again for your time 👍

@magjac
Copy link
Owner

magjac commented May 5, 2020

@GordonSmith
Copy link
Contributor

GordonSmith commented May 8, 2020

Quick note on "wasmFolder" -

The wasm file typically needs to be loaded at runtime (on demand) similar to workers. The wrapping JS generated by emscripten includes some logic which attempts to identify the location of the "wrapper JS" and will assume that the wasm file is located in the same folder as it.

What happens is that the wrapper JS ends up getting moved and bundled by various tools (babel, typescript, webpack etc.), now the auto location code will still do its thing, but since its now in your dist folder, its going to assume the wasm file is in there also. Hence simply copying the wasm "resource" there is probably the simplest solution.

The wasmFodler is a way to specify an alternative location for the wasm (from the requesting html pages point of view).

IOW the following should work fine for most cases: wasmFolder("https://cdn.jsdelivr.net/npm/@hpcc-js/wasm@0.3.13/dist");

But you have to be carful that the wrapper version and wasm version match 100%

@magjac
Copy link
Owner

magjac commented May 8, 2020

@GordonSmith The problem we're having with the development servers for both React and Vue.js is that they don't seem to produce a build in the file system (at least I haven't been able to find it). I guess they are in memory somewhere. In order to get this to work, one needs to figure out where to put the wasm before starting the server so that it finds it and incorporates it into the build.

You can try @avimehenwal's test case yourself if you want to have a stab at it.

Your workaround of course works, but is very impractical for reasons you mention, but also since it requires Internet access which prohibits you to do development and testing offline.

@GordonSmith
Copy link
Contributor

Is there a test repo I can look at (minimal?)

@magjac
Copy link
Owner

magjac commented May 8, 2020

Here is the sample code I am trying to run, with instruction to deploy
https://github.com/avimehenwal/graphviz-dot

Component File -> https://github.com/avimehenwal/graphviz-dot/blob/master/src/components/HelloWorld.vue

@GordonSmith
Copy link
Contributor

That repo is missing source?

ERROR  Failed to compile with 1 errors                                                                                                      13:37:41
This relative module was not found:

* ./components/GraphvizViewer.vue 

@magjac
Copy link
Owner

magjac commented May 8, 2020

Try the commit before

@GordonSmith
Copy link
Contributor

I "think" your dev dependency of "@hpcc-js/wasm": "^0.3.11" is causing the issue as third party consumers end up mixing versions of the physical wasm and the JS wrapper.

If you change it to "@hpcc-js/wasm": "0.3.13" then I suspect it will start to work...

@GordonSmith
Copy link
Contributor

GordonSmith commented May 8, 2020

Remember folks who consume your library may end up using either of:

  "main": "build/d3-graphviz.js",

or

  "jsnext:main": "index",

and with a dependency of:

    "@hpcc-js/wasm": "^0.3.11",

@GordonSmith
Copy link
Contributor

Scratch that - I was fooled by Vue returning a "html" page in lieu of the missing wasm file - investigating more!

@GordonSmith
Copy link
Contributor

GordonSmith commented May 8, 2020

For development (serve) the following works for me:

cp -p node_modules/@hpcc-js/wasm/dist/graphvizlib.wasm public/js

It might also work for production as well, but I was not sure how to test correctly...

@GordonSmith
Copy link
Contributor

Yea that works for prod (since it simply copies the contents of "public" into "dist". At least it makes some sense - the vue generated JS essentially lives in "public/js" so when it goes to load the wasm it defaults to that folder.

@magjac
Copy link
Owner

magjac commented May 8, 2020

I think you must have made a typo. This is what works for me:
EDIT: I see now that you had already corrected it.

cp -p node_modules/@hpcc-js/wasm/dist/graphvizlib.wasm public/js

Preceded of course by:

mkdir -p public/js

Anyway, a really big thanks for finding this out 💪

@magjac
Copy link
Owner

magjac commented May 8, 2020

Even better is to create a symbolic link which you can commit to git and then never worry about again:

mkdir -p public/js
cd public/js
ln -s ../../node_modules/@hpcc-js/wasm/dist/graphvizlib.wasm .
git add graphvizlib.wasm 
git commit

@GordonSmith
Copy link
Contributor

I suspect if I "knew" vue then I would have been able to answer straight away...

BTW my comments above are still true for your jsnext + main entry points in your package.json (and you should probably remove the "^" for the @hpcc-js/wasm dependency). The original error about the mis matched "magic word" is normally associated with mis matched wasm + JS wrapper - which is why I went off on that tangent - in this case it was mismatched because Vue was barfing back html instead of a 404.

magjac added a commit that referenced this issue May 9, 2020
@magjac
Copy link
Owner

magjac commented May 9, 2020

@GordonSmith I've upgraded to @hpcc-js/wasm 0.3.13 and pinned it to that exact version (and discovered a bug in d3-graphviz in the making).

When I have more time, I will try to understand what your comment about jsnext + main entry points means and what I should do about it.

@GordonSmith
Copy link
Contributor

If your pinned then you don't have anything to do - but your essentially releasing two versions of your library - a bundled version (main) and an es6 version (jsnext).

The bundled version "probably" contains my wrapper versioned as of the time you built the bundle. While the JSNext version only references a local copy of @hpcc-js/wasm - which may well be newer (when using the hat). So there is potential for them to be out of sync in a "consumers" development environment.

(if you don't bundle my wrapper then your probably ok).

Also I need to fix my auto versioning to be a bit stricter...

@magjac
Copy link
Owner

magjac commented May 9, 2020

Thanks @GordonSmith. I double-checked to see if I inadvertently bundled your wrapper and I don't (but found yet another d3-graphviz bug in the making 😳).

A very educational exercise, this. Thanks @avimehenwal & @GordonSmith.

@magjac magjac closed this as completed May 9, 2020
@magjac magjac added the not an issue Asking for help or other discussions label May 9, 2020
@magjac magjac reopened this May 9, 2020
@magjac magjac closed this as completed May 10, 2020
@avimehenwal
Copy link
Author

Superthanks @magjac and @GordonSmith 👍
I just double checked everything and was able to make it work on sample test case project. Not a a bug, only I missed to check and add wasm properly. Rookie mistake from my side 😄
Appreciate very much your time and efforts on this.

PS: not much but I would like to offer BAT as a token of appreciation to both, if you guys will accept it XD

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
not an issue Asking for help or other discussions
Projects
None yet
Development

No branches or pull requests

3 participants