<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>FileAPI Test: filereader_file</title> <link rel="author" title="Intel" href="http://www.intel.com"> <link rel="help" href="http://dev.w3.org/2006/webapi/FileAPI/#FileReader-interface"> <link rel="help" href="http://dev.w3.org/2006/webapi/FileAPI/#file"> <script src="/resources/testharness.js"></script> <script src="/resources/testharnessreport.js"></script> </head> <body> <div> <p>Test step:</p> <ol> <li>Download <a href="support/blue-100x100.png">blue-100x100.png</a> to local.</li> <li>Select the local file (blue-100x100.png) to run the test.</li> </ol> </div> <form name="uploadData"> <input type="file" id="fileChooser"> </form> <div id="log"></div> <script> var fileInput = document.querySelector('#fileChooser'); var reader = new FileReader(); //readType: 1-> ArrayBuffer, 2-> Text, 3-> DataURL var readType = 1; setup({ explicit_done: true, explicit_timeout: true, }); on_event(fileInput, "change", function(evt) { reader.readAsArrayBuffer(fileInput.files[0]); }); on_event(reader, "load", function(evt) { if (readType == 1) { test(function() { assert_true(reader.result instanceof ArrayBuffer, "The result is instanceof ArrayBuffer"); }, "Check if the readAsArrayBuffer works"); readType++; reader.readAsText(fileInput.files[0]); } else if (readType == 2) { test(function() { assert_equals(typeof reader.result, "string", "The result is typeof string"); }, "Check if the readAsText works"); readType++; reader.readAsDataURL(fileInput.files[0]); } else if (readType == 3) { test(function() { assert_equals(typeof reader.result, "string", "The result is typeof string"); assert_equals(reader.result.indexOf("data"), 0, "The result starts with 'data'"); assert_true(reader.result.indexOf("base64") > 0, "The result contains 'base64'"); }, "Check if the readAsDataURL works"); done(); } }); </script> </body> </html>