chromium/fuchsia_web/webengine/test/data/mic.html

<script>
  let getUserMediaError = null;

  function callGetUserMedia(haveAccess) {
    return navigator.mediaDevices.getUserMedia({ audio: true, video: false })
      .then(() => {
        if (!haveAccess) {
          throw "getUserMedia() succeeded when the page doesn't have " +
                "microphone access";
        }
      })
      .catch((e) => {
        getUserMediaError = e.name;
      });
  }

  function callEnumerateDevices(haveAccess) {
    return navigator.mediaDevices.enumerateDevices().then((devices)=>{
      var found = false;
      for (d of devices) {
        if (d.kind == "audioinput") {
          found = true;
          if (d.deviceId == "" && haveAccess) {
            throw "deviceId must not be empty when mic permission is granted.";
          } else if (d.deviceId != "" && !haveAccess) {
            throw "deviceId must be non-empty only when mic permission is granted.";
          }
          if (d.label != "" && !haveAccess) {
            throw "device label must be empty unless mic permission is granted.";
          }
          // TODO(crbug.com/40124154): Verify that d.label is set when microphone
          // permission is granted.
        }
      }
      if (!found) {
        throw "enumerateDevices() didn't return any audioinput devices.";
      }
    });
  }

  // NoPermission is passed in the URL when the page doesn't have microphone
  // access.
  var haveAccess = (window.location.href.indexOf("NoPermission") < 0);

  callGetUserMedia(haveAccess)
  .then(() => { return callEnumerateDevices(haveAccess); })
  .then(() => {
    var title = "ended";
    if (getUserMediaError)
      title += "-" + getUserMediaError;
    document.title = title;
    if (window.parent) {
      window.parent.postMessage({title: document.title}, "*");
    }
  });
</script>