Giter VIP home page Giter VIP logo

valence's Introduction

This project is no longer maintained

Mozilla no longer maintains this project. Cross-browser remote debugging is still a priority. To enable browser/device agnostic inspection and debugging, we intend to make our tools be directly compatible with the Chrome DevTools Protocol.


Valence

Valence is a Firefox add-on that is installed by default with Firefox Developer Edition. It is a remote debugging protocol adapter that allows you to debug Chrome and Safari (desktop and mobile) from Firefox, using WebIDE.

Documentation on how to use WebIDE and Valence is available on the Mozilla Developer Network.

How to Interact With The Thing

There are three ways to interact with this tool right now: WebIDE, some Developer Toolbar commands, or a toolbar button.

WebIDE is the main tool for debugging remote devices and this add-on provides additional runtime options in the Custom section for Chrome and iOS. You can learn more about WebIDE in the Mozilla Developer Network.

If you prefer interacting with a command-line tool, use the commands chrome, android and ios from the Developer Toolbar. These should automatically launch a browser for you and connect appropriately - assuming you've met the installation requirements below.

For a quick setup when working on the add-on itself, it will add a (weirdly ambiguous) new icon to your browser, once you set the pref [email protected] to true. You can toggle its value from about:config, or by adding it in a JSON file with preference overrides that you provide to jpm via the --prefs option (check out jpm --help for the right syntax). When you click it, it will attempt to connect the Firefox DevTools to whatever is on port 9222. For example, if you start an instance of Chrome Canary on port 9222 (use flag --remote-debugging-port=9222), it will try and connect to that.

Installation for All Y'all

Before you can build and run the extension, here are a few things you'll need to do:

  1. git clone [email protected]:mozilla/valence.git

  2. Make sure you have an updated copy of Firefox Nightly installed. If you need to install Nightly, you can get it here.

  3. Make sure you have node (and subsequently npm) installed. Instructions for that are here.

  4. Install jpm with npm install -g jpm. jpm is a node utility for developing browser add-ons.

Then from your extension folder you can use jpm run -v, with the-b option to use your recent Firefox Nightly, to run a new Firefox process with the extension installed.

Now that you've done that, you can follow the instructions below for each applicable debug target/browser.

For more detailed building instructions and instructions for building the ios-webkit-debug-proxy binaries, see building.html.

Debugging Chrome on Desktop

Clicking the button on the Firefox toolbar will connect to the debug target on port 9222. To debug Chrome on Desktop, the process must have remote debugging enabled and set to this port.

The important flag is --remote-debugging-port=9222. There is a page with information on how to run the Chrome process with these flags.

There are some other flags that can be helpful if you'd like to run this alongside another Chrome profile. By running with --no-first-run, --no-default-browser-check, and --user-data-dir you can run this process alongside another Chrome profile.

For example, on OSX, you could run the following command to start a debuggable copy of Chrome:

> /Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222 --no-first-run --no-default-browser-check --user-data-dir=$(mktemp -d -t 'chrome-remote_data_dir')

If you click on the toolbar button and nothing happens, you most likely don't have anything running on port 9222. Check the Browser Console to see what has gone wrong.

Debugging Chrome on Android

In addition to the installation instructions, follow these instructions to turn on remote debugging and set up adb.

Debugging Safari, Firefox, and other WebViews on iOS

In addition to the installation instructions, you will need to enable developer support on your device. Follow the instructions on this page (in the "To enable Web Inspector on iOS" section) to get started. Note: you can also use the iOS simulator if you have Xcode installed.

Debugging Safari, Firefox, and other WebViews on iOS is possible through the use of the following open source libraries that come bundled with this extension:

  1. ios_webkit_debug_proxy version 1.4 on both OS X and Linux
  2. libimobiledevice version 1.1.5 on OS X, 1.2.0pre on Linux
  3. libplist version 1.10 on OS X, 1.12pre on Linux
  4. libusbmuxd version 1.0.8 on OS X, 1.0.0pre on Linux

On Windows we are using the ios-webkit-debug-proxy port at commit 20679aaa990b82e7fb43e434e271cce17e327f90. An additional runtime requirement on Windows is to have iTunes installed, or at least the Apple Mobile Device Support and Apple Application Support applications that come with it.

Why did you start this project?

We realized that debugging individual browsers in their respective vendor silos is painful, frustrating, and at times downright demoralizing. We wanted to make better tools so that web developers are relieved of this anguish (as much as possible). You should test this thing as it becomes more stable, and let us know how we can make the cross-platform debugging experience better.

Notes

Note that this project should be treated as ALPHA software - implementation is far from finished.

The UI for interacting with this project will change soon - the commands will likely stick around but the ambiguous button in your browser will probably not. Eventually there will even be nicer buttons than any of this. Dare to dream.

If you notice that the install or usage instructions should be different, please help us by sending a PR for this README. This project is changing fast and so information here may be out of date.

valence's People

Contributors

artygus avatar bgrins avatar campd avatar captainbrosset avatar gabrielluong avatar isaacschemm avatar jimblandy avatar jlongster avatar jryans avatar leostratus avatar mozilla-github-standards avatar ochameau avatar past avatar paulirish avatar paulrouget avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

valence's Issues

Console previewers don't work

The web console has a number of formatters for various value types that are currently not being used. This results in [] appearing as [object Array] instead of Array [ ].

Add layout-view automargin support

The layout-view expects a autoMargins property in the response object when it calls styles.getLayout.
Right now, our ChromiumPageStyleActor.getLayout implementation returns an empty object for autoMargins.

The object is supposed to be something like {top: "auto", right: "auto"}, depending on which margins have been set to auto.

Cannot Disconnect from iOS after device was idle or Safari was closed

  1. Connect to Safari on iOS
  2. Press device's Home button, on console:
    JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
    {"id":14,"method":"Page.disable","params":{}}

The device is no longer connected although it appear as it is (Safari tab remains in view), the Disconnect button is disabled. It still cannot be used after returning to Safari after pressing the device's Home button.

If Safari is closed on device, the opened tab disappears from project view and the Disconnect button is unavailable.

Evaluating a non-existent variable breaks the console

Evaluating a non-existing identifier in the console results in the following error:

TypeError: handle is undefined
Stack:
exports.gripType<.write@resource://gre/modules/addons/XPIProvider.jsm -> jar:file:///tmp/9c214bf5-37ff-4521-b990-442dd6041ef7/extensions/[email protected]!/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/value.js:47:9
types.addDictType/<.write@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:216:23
RetVal<.write@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:490:12
Response<.write/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:643:1
Response<.write@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:641:23
actorProto/</handler/sendReturn@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:949:26
resolve@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/deprecated-sync-thenables.js:40:40
Handler.prototype.process@resource://gre/modules/Promise.jsm -> resource://gre/modules/Promise-backend.js:865:23
this.PromiseWalker.walkerLoop@resource://gre/modules/Promise.jsm -> resource://gre/modules/Promise-backend.js:744:7

Switching to a new tab on Safari doesn't update the project

Opening a new tab in Safari (iOS 8.1) doesn't update WebIDE's current app/project (there is nothing shown here). The device still appears as connected and the Disconnect button is not available.

Console:
JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
{"id":220,"method":"DOM.hideHighlight","params":{}}

Ability to debug WebViews

With Safari on OSX, I can debug WebViews embedded in native apps.
However, with the adapter running on linux, I can only debug safari itself. It will not accept connections when a native app with a WebView is open.

It would be nice to also support this, if the platform limitations allow this.

Hide pretty-printing & blackboxing buttons (or make them work)

The pretty-printing & blackboxing doesn't work right now and we probably won't get it working, and we talked about hiding the buttons. Not sure how hard this will be. It will require a patch to Firefox that needs to be uplifted to Aurora so I'll look into it now so we have a chance of getting it landed.

(I'll open a bug in bugzilla instead once this gets more serious)

Hovering selectors in the rule-view and computed-view doesn't highlight the corresponding nodes

This was added recently to the FirefoxDevTools and is based on a new SelectorHighlighter in the back-end that retrieves all nodes that match a given selector and highlights them all.

Probably not the first thing to work on in the inspector, especially that there's a trait on the root actor that tells the front-end if this special highlighter exists or not, so it doesn't break if it's not here.
But if chromium's DOM.highlightNode request allows several nodes to be highlighted at the same time, this would be fairly easy to implement.

Selecting an element from the page doesn't work on iOS

I thought I would be able to fix this quickly, but the reason why this doesn't work eludes me for now, so I'm creating an issue for it.

  • When clicking on the "pick" icon, this sends a request to our highlighter actor which then sends a DOM.setInspectModeEnabled request via the ios protocol
  • As specified in the protocol descriptor, this is supposed to then emit a Inspector.inspect event when an element is selected from the page.

So, we have 2 problems:

  • the code in walker.js for now only listens to DOM.inspectNodeRequested, so we need to make it also listen to Inspector.inspect,
  • even when done, nothing happens when selecting an element in the page.

What's weird is that using the ios webkit proxy with the google chrome devtools, I can sort of see that the Inspector.inspect event is indeed sent in the debug output, but in our case, nothing gets sent back when selecting an element from the page.

"Chrome on Android" option not available in WebIDE, Win 7

Prerequisites:

  • Google Chrome for Android installed from Google Play on a device - open a page
  • Android SDK installed on Windows
  • USB debugging option enabled on device

Steps to reproduce: Open WebIDE from Developers Tools latest build and select "Chrome on Android" option from "Select runtime" menu

ER: The page opened on device using Chrome can be debugged from WebIDE

AR: The "Chrome on Android" option doesn't appear on WebIDE's menu

Gracefully unregister

We're adding this addon to WebIDE's addon manager, where the user might disable the addon. We need to unregister properly the runtimes.

debugger loads up in paused state in Chrome

If you click on the debugger and switch to another tool you'll see that the debugger tab is green meaning that it's paused. The UI doesn't show any reason is should be paused. For some reason it always loads up paused. Pressing the button to resume doesn't seem to do anything.

EDIT: ok, I'm starting to get the hang of this. This only happens in Chrome, works fine in iOS.

HTML in debugger is incorrect

Haven't done much research, but getting the source of the HTML page is wrong, you get a random script it seems (seems to vary depending on timing, it's weird). It should be pretty easy to do what we do now for Firefox and just re-fetch the HTML.

uncaught exceptions on page load don't show up in console

Filing this away for the future, I don't have time to look into it right now, but if you load up a page with something like this:

function foo() {
  throw new Error(5);
}

foo()

The error isn't shown anywhere if you are connected and reload the page. It should show up in the console.

Can not debug desktop Chrome Canary anymore

I haven't been able to debug Chrome Canary anymore for a few days now.
Version is 40.0.2203.3 canary (64-bit).
Debugging Chrome release does work though. Version is 38.0.2125.111.

I get the following error message when trying to connect:

screenshot 2014-10-30 08 46 09

And in the logs:

JPM info console.log: fxdevtools_adapters: <<<<<< Connecting to ws://localhost:9222/devtools/page/B47ACBC3-2A4A-40F1-8FD1-6D8B2E0EE8F8...

JPM info console.log: fxdevtools_adapters: >>>>>> Connection established

JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
{"id":1,"method":"Inspector.enable","params":{}}

JPM info console.log: fxdevtools_adapters: >>>>>> Received from device
{"id":1,"result":{}}

JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
{"id":2,"method":"Page.getResourceTree","params":{}}

JPM info console.log: fxdevtools_adapters: >>>>>> Received from device
{"id":2,"result":{"frameTree":{"frame":{"id":"869.1","loaderId":"869.2","url":"https://www.google.fr/search?q=test&oq=test&aqs=chrome.0.0l6.443j0j7&sourceid=chrome&es_sm=91&ie=UTF-8","mimeType":"text/html","securityOrigin":"https://www.google.fr"},"resources":[{"url":"https://ssl.gstatic.com/gb/images/i1_71651352.png","type":"Image","mimeType":"image/png"},{"url":"https://www.google.fr/gen_204?v=3&s=web&imc=1&imn=1&imp=0&ei=pu9RVJuzDJLbaojkgYgF&e=3700318,4005878,4016824,4017981,4018673,4019182,4019511,4020347,4020562,4020666,4020873,4020921,4021162,4021364,4021587,4021597,4021775,4022495,4022574,4022756,4023083,4023373,4023979,4024410,4024660,8500271,8500325,8500393,8500700,10200083,10200716&atyp=csi&adh=&xjs=init.69.30.sb.45.p.9.m.3.spch.2.dvl.2&action=&srt=314&p=s&npn=1&rt=xjsls.202,prt.203,xjses.278,xjsee.390,xjs.406,ol.456,iml.203,wsrt.305,cst.0,dnst.0,rqst.353,rspt.243","type":"Image","mimeType":"text/html"},{"url":"%3D%3D","type":"Image","mimeType":"image/gif"},{"url":"https://www.google.fr/images/nav_logo195.png","type":"Image","mimeType":"image/png"},{"url":"","type":"Image","mimeType":"image/gif"},{"url":"https://www.google.com/textinputassistant/tia.png","type":"Image","mimeType":"image/png"}]}}}

JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
{"id":3,"method":"Page.enable","params":{}}

JPM info console.log: fxdevtools_adapters: >>>>>> Received from device
{"id":3,"result":{}}

JPM info console.log: fxdevtools_adapters: <<<<<< Sent to device
{"id":4,"method":"CSS.enable","params":{}}

JPM info console.log: fxdevtools_adapters: >>>>>> Received from device
{"error":{"code":-32000,"message":"DOM agent needs to be enabled first."},"id":4}

Hide toolbar icon for production use

The toolbar icon is convenient for working on this add-on, but I am not sure we need it for real use, since we can expose the same actions through WebIDE, which seems more consistent since that's how you get to the other runtimes. Thoughts? We could potentially keep it just for add-on development, but remove it from the release build.

Naturally, I would not hide it until we're actually exposing the same functionality in the runtime list (it's not clearly labelled that way at the moment).

There is no image preview tooltip in the markup-view

Using the resource-store class, it should be feasible to get the content for a given image URL so that we can implement NodeActor.getImageData (marked TODO so far).
This will make markup-view image preview tooltips work.

Inspector doesn't walk into iframes

Tested here: http://jsbin.com/sorakeloxaku/1/edit
STR:

  • Click on the element picker icon
  • Select the test element in the right hand side iframe

JPM error Message: TypeError: node is undefined
Stack:
ChromiumWalkerActor<.ensurePathToRoot@resource://gre/modules/addons/XPIProvider.jsm -> jar:file:///var/folders/17/384y6ycd72n0_fpjwwcl01y80000gn/T/a4197725-2641-4d1d-b939-02c33f221391/extensions/[email protected]!/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/walker.js:766:9
ChromiumWalkerActor<.onInspectNodeRequested@resource://gre/modules/addons/XPIProvider.jsm -> jar:file:///var/folders/17/384y6ycd72n0_fpjwwcl01y80000gn/T/a4197725-2641-4d1d-b939-02c33f221391/extensions/[email protected]!/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/walker.js:457:23
emit@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/commonjs/sdk/event/core.js:96:9
TabConnection<.onMessage@resource://gre/modules/addons/XPIProvider.jsm -> jar:file:///var/folders/17/384y6ycd72n0_fpjwwcl01y80000gn/T/a4197725-2641-4d1d-b939-02c33f221391/extensions/[email protected]!/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/rpc.js:56:7

Also, trying to access the iframe just by expanding nodes in the markup-view shows that its a childless node that can't be expanded.

Error on re-install

My lame guess is some server-side code isn't cleaned up on unload - the workaround is just to re-start nightly.

I see this error:

JPM info console.error: fxdevtools_adapters:

JPM error Message: Error: Type 'chromium_grip' already exists.
Stack:
types.addType@resource://gre/modules/devtools/server/protocol.js:142:1
@resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/value.js:25:20
@resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/webconsole.js:8:16
@resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/root.js:15:32
@resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/server.js:15:29
@resource://fxdevtools-adapters-at-mozilla-dot-org/lib/main.js:11:16
run@resource://gre/modules/commonjs/sdk/addon/runner.js:145:19
startup/</<@resource://gre/modules/commonjs/sdk/addon/runner.js:86:7
Handler.prototype.process@resource://gre/modules/Promise-backend.js:865:23
this.PromiseWalker.walkerLoop@resource://gre/modules/Promise-backend.js:744:7

Inspector breaks when navigating pages for remote browser

STR:

Expected:
Things still work

Actual:
The inspector turns white, and I see errors like this in the browser console:

TypeError: node is null
Stack trace:
ChromiumWalkerActor<.children<@resource://gre/modules/addons/XPIProvider.jsm -> file:///Users/bgrinstead/Library/Application%20Support/Firefox/Profiles/pww9ccdu.dev/extensions/[email protected]/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/walker.js:684:9
TaskImpl_run@resource://gre/modules/Task.jsm:314:40
TaskImpl@resource://gre/modules/Task.jsm:275:3
createAsyncFunction/asyncFunction@resource://gre/modules/Task.jsm:249:14
actorProto/</handler@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/server/protocol.js:941:19
Connection<.onPacket<@resource://gre/modules/addons/XPIProvider.jsm -> file:///Users/bgrinstead/Library/Application%20Support/Firefox/Profiles/pww9ccdu.dev/extensions/[email protected]/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://fxdevtools-adapters-at-mozilla-dot-org/lib/chromium/server.js:50:7
TaskImpl_run@resource://gre/modules/Task.jsm:314:40
TaskImpl@resource://gre/modules/Task.jsm:275:3
createAsyncFunction/asyncFunction@resource://gre/modules/Task.jsm:249:14
LocalDebuggerTransport.prototype.send/<@resource://gre/modules/devtools/dbg-client.jsm -> resource://gre/modules/devtools/transport/transport.js:545:11
makeInfallible/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/DevToolsUtils.js:83:14
makeInfallible/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/DevToolsUtils.js:83:14
 protocol.js:852
"SEND: {
  "from": "chromium2.chromium_domwalker11",
  "error": "unknownError",
  "message": "TypeError: node is null"
}" server.js:33
"Protocol error (unknownError): TypeError: node is null" protocol.js:16
"Protocol error (unknownError): TypeError: node is null" deprecated-sync-thenables.js:48

Scripts inside HTML pages aren't properly highlighted

This happens in the debugger panel.
It looks like chromium doesn't provide the whole text content for scripts that are inside HTML documents. It only returns the script itself. And our front-end probably expects HTML so tries to highlight it as such.

Rename to Valence

We're starting to publish videos and docs and such with the name "Valence" now.

We should at least rename the add-on. We could also rename the repo too.

WebIDE would need a string change as well to update it's pre-install name for the add-on.

Switching between Inspector of two Google Chrome tabs removes Inspector's content

Used fxdt-adapters with latest merge: "Merge pull request #80 from jlongster/master"

  1. Opened Google Chrome and entered two different websites in two tabs
  2. Connected to Chrome from WebIDE
  3. Selected one tab and opened the Inspector for it - Inspector looks good
  4. Selected the other tab - the Inspector was already open
  5. Switched to the first tab - Inspector was black
  6. Returned to the second tab - Inspector contained no data

This doesn't occur with Debugger tab

Move to mozilla org

We should move this to the main Mozilla GitHub org now that it's more official.

@paulrouget said we should be careful to remove this repo though, or else all the PRs will go to @campd or something.

API interface for runtime connection connect

Given:

 let iOSRuntime = {
    getName: function() {
      return "iOS proxy";
    },
    connect: function(connection) {
      let transport = server.connect("http://localhost:9222");
      connection.connect(transport);
      return promise.resolve();
    },
  }
  AppManager.runtimeList.custom.push(iOSRuntime);

What API interface is transport expected to have for use in connection.connect(transport)?

I am trying to figure out where this fits in the Debugger / RDP / Debug server/client picture.

I am trying to write a debug server (assuming the devtools debugger UI is the client?) I can run in an extension to simulate a debuggable runtime.

Debugging Google Chrome under Mac OSX 10.9.5 issues

I used Nightly 36.0a1 2014-10-27:

  • Style Editor loads forever when opening chrome://newtab for the first time
  • The name of the debugging window remains chrome://newtab even after opening other pages in the same tab or in other tabs
  • The content on Inspector tab turns white after some time, see http://i.imgur.com/csR4wse.jpg; modified rules are still applied
  • After inspecting some pages, the console is not refreshed any more, it has to be closed and reopened

(Harmless) error when switching to iOS proxy in webIDE

I get this error in the console when firing up WebIDE and selecting "iOS proxy". I don't have any apps installed and haven't used WebIDE before, so that might be related. The error seems harmless and I can use fever dream fine.

JPM info Handler function DebuggerClient.requester request callback threw an exception: Error: 'getAll' request packet has no destination.
Stack: DebuggerClient.prototype.request@resource://gre/modules/devtools/dbg-client.jsm:667:1
AppActorFront.prototype.watchApps@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/app-actor-front.js:570:35
AppManager.onConnectionChanged/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource:///modules/devtools/webide/app-manager.js:139:9
DebuggerClient.requester/</<@resource://gre/modules/devtools/dbg-client.jsm:348:9
makeInfallible/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/DevToolsUtils.js:83:14
emit@resource://gre/modules/addons/XPIProvider.jsm -> jar:file:///var/folders/kx/1gnshz117g378t2d7kwqg9_c0000gn/T/20e9725b-17f3-449e-b9a3-36579d7fe67e/extensions/[email protected]!/bootstrap.js -> resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/commonjs/sdk/event/core.js:96:9
Request.prototype.emit@resource://gre/modules/devtools/dbg-client.jsm:1092:29
DebuggerClient.prototype.onPacket/<@resource://gre/modules/devtools/dbg-client.jsm:931:9
resolve@resource://gre/modules/devtools/deprecated-sync-thenables.js:40:40
then@resource://gre/modules/devtools/deprecated-sync-thenables.js:20:43
then@resource://gre/modules/devtools/deprecated-sync-thenables.js:58:9
DebuggerClient.prototype.onPacket@resource://gre/modules/devtools/dbg-client.jsm:869:1
LocalDebuggerTransport.prototype.send/<@resource://gre/modules/devtools/dbg-client.jsm -> resource://gre/modules/devtools/transport/transport.js:545:11
makeInfallible/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/DevToolsUtils.js:83:14
makeInfallible/<@resource://gre/modules/commonjs/toolkit/loader.js -> resource://gre/modules/devtools/DevToolsUtils.js:83:14
Line: 667, column: 0

Dev doc needed

So far I've only brushed the surface of the addon by fixing a few inspector-related bugs, but I feel like I'm missing a lot of information when it comes to how the addon actually works.
Here are some of the questions I have in mind:

  • why are actors prefixed with chromium_ knowing that we support both blink and webkit-based browsers for now. Is this just a naming thing?
  • What happens when/if we want to support other browsers with completely different protocols? Where would the code to switch from one implementation to the other be?
  • How do we deal with differences between ios and chrome protocols? So far, I've been confronted with this only a couple of times, and it was easily solved with an if (supports this) { ... } else (supports that) { ... }. More importantly, how are we going to deal with new protocol versions?
    I believe answering these questions in the README.md or in the project wiki would not only be beneficial to me but to anyone who's willing to help on the project. That's why I'm filing this issue.
    I'm fine to write that doc, but I need some light on the subject.

Supporting event tooltips in the markup-view

It looks like both the ios and chrome protocols do have a DOM.getEventListenersForNode command, so we should be able to support some kind of event tooltip in the markup-view.

The response object contains a list of eventlisteners that have the following format:

[
  { "name": "type", "type": "string", "description": "<code>EventListener</code>'s type." },
  { "name": "useCapture", "type": "boolean", "description": "<code>EventListener</code>'s useCapture." },
  { "name": "isAttribute", "type": "boolean", "description": "<code>EventListener</code>'s isAttribute." },
  { "name": "nodeId", "$ref": "NodeId", "description": "Target <code>DOMNode</code> id." },
  { "name": "handlerBody", "type": "string", "description": "Event handler function body." },
  { "name": "location", "$ref": "Debugger.Location", "description": "Handler code location." },
  { "name": "sourceName", "type": "string", "optional": true, "description": "Source script URL." },
  { "name": "handler", "$ref": "Runtime.RemoteObject", "optional": true, "description": "Event handler function value." }
]

The reflow actor doesn't work properly on ios

See https://github.com/campd/fxdt-adapters/blob/master/lib/chromium/reflow.js#L16
Pull request #89 will make the layout-view on ios, so we should spend more time trying to make the reflow actor fully work on ios too, so that the layout-view refreshes as dimensions change.

One good way to test this is:

  • start with the iDevice in landscape mode
  • select an element
  • switch to the layout-view inspector sidebar panel
  • rotate the device to portrait mode

The layout-view should be automatically refreshed to show the new dimensions.

Scratchpad doesn't work

It should be pretty simple to get Scratchpad to work, since it's using the web console actor, but I get the following error when trying to evaluate or run anything in Scratchpad:

A coding exception was thrown in a Promise resolution callback.
See https://developer.mozilla.org/Mozilla/JavaScript_code_modules/Promise.jsm/Promise

JPM info Full message: TypeError: aError is undefined
Full stack: SP_writeAsErrorComment@chrome://browser/content/devtools/scratchpad.js:924:11
SP_display/<@chrome://browser/content/devtools/scratchpad.js:610:9
Handler.prototype.process@resource://gre/modules/Promise.jsm -> resource://gre/modules/Promise-backend.js:865:23
this.PromiseWalker.walkerLoop@resource://gre/modules/Promise.jsm -> resource://gre/modules/Promise-backend.js:744:7

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.