You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cordova.apache.org by pu...@apache.org on 2014/08/19 03:38:38 UTC

[1/6] Merging to work on top of test framework changes

Repository: cordova-plugin-file
Updated Branches:
  refs/heads/master 33797d58c -> 3086907f8


http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/blob/f4eb0a09/tests/tests.js
----------------------------------------------------------------------
diff --cc tests/tests.js
index 2f0178b,0000000..0d6edc8
mode 100644,000000..100644
--- a/tests/tests.js
+++ b/tests/tests.js
@@@ -1,3059 -1,0 +1,3152 @@@
 +/*
 + *
 + * Licensed to the Apache Software Foundation (ASF) under one
 + * or more contributor license agreements. See the NOTICE file
 + * distributed with this work for additional information
 + * regarding copyright ownership. The ASF licenses this file
 + * to you under the Apache License, Version 2.0 (the
 + * "License"); you may not use this file except in compliance
 + * with the License. You may obtain a copy of the License at
 + *
 + * http://www.apache.org/licenses/LICENSE-2.0
 + *
 + * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an
 + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 + * KIND, either express or implied. See the License for the
 + * specific language governing permissions and limitations
 + * under the License.
 + *
 + */
 +exports.defineAutoTests = function () {
 +    describe('File API', function () {
 +        // Adding a Jasmine helper matcher, to report errors when comparing to FileError better.
 +        var fileErrorMap = {
 +            1 : 'NOT_FOUND_ERR',
 +            2 : 'SECURITY_ERR',
 +            3 : 'ABORT_ERR',
 +            4 : 'NOT_READABLE_ERR',
 +            5 : 'ENCODING_ERR',
 +            6 : 'NO_MODIFICATION_ALLOWED_ERR',
 +            7 : 'INVALID_STATE_ERR',
 +            8 : 'SYNTAX_ERR',
 +            9 : 'INVALID_MODIFICATION_ERR',
 +            10 : 'QUOTA_EXCEEDED_ERR',
 +            11 : 'TYPE_MISMATCH_ERR',
 +            12 : 'PATH_EXISTS_ERR'
 +        },
 +        root,
 +        temp_root,
 +        persistent_root;
 +        beforeEach(function (done) {
 +            // Custom Matchers
 +            jasmine.Expectation.addMatchers({
 +                toBeFileError : function () {
 +                    return {
 +                        compare : function (error, code) {
 +                            var pass = error.code == code;
 +                            return {
 +                                pass : pass,
 +                                message : 'Expected FileError with code ' + fileErrorMap[error.code] + ' (' + error.code + ') to be ' + fileErrorMap[code] + '(' + code + ')'
 +                            };
 +                        }
 +                    };
 +                },
 +                toCanonicallyMatch : function () {
 +                    return {
 +                        compare : function (currentPath, path) {
 +                            var a = path.split("/").join("").split("\\").join(""),
 +                            b = currentPath.split("/").join("").split("\\").join(""),
 +                            pass = a == b;
 +                            return {
 +                                pass : pass,
 +                                message : 'Expected paths to match : ' + path + ' should be ' + currentPath
 +                            };
 +                        }
 +                    };
 +                },
 +                toFailWithMessage : function () {
 +                    return {
 +                        compare : function (error, message) {
 +                            var pass = false;
 +                            return {
 +                                pass : pass,
 +                                message : message
 +                            };
 +                        }
 +                    };
 +                }
 +            });
 +            //Define global variables
 +            var onError = function (e) {
 +                console.log('[ERROR] Problem setting up root filesystem for test running! Error to follow.');
 +                console.log(JSON.stringify(e));
 +            };
 +            window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, function (fileSystem) {
 +                root = fileSystem.root;
 +                // set in file.tests.js
 +                persistent_root = root;
 +                window.requestFileSystem(LocalFileSystem.TEMPORARY, 0, function (fileSystem) {
 +                    temp_root = fileSystem.root;
 +                    // set in file.tests.js
 +                    done();
 +                }, onError);
 +            }, onError);
 +        });
 +        // HELPER FUNCTIONS
 +        // deletes specified file or directory
 +        var deleteEntry = function (name, success, error) {
 +            // deletes entry, if it exists
 +            window.resolveLocalFileSystemURL(root.toURL() + '/' + name, function (entry) {
 +                if (entry.isDirectory === true) {
 +                    entry.removeRecursively(success, error);
 +                } else {
 +                    entry.remove(success, error);
 +                }
 +            }, success);
 +        };
 +        // deletes file, if it exists, then invokes callback
 +        var deleteFile = function (fileName, callback) {
 +            root.getFile(fileName, null, // remove file system entry
 +                function (entry) {
 +                entry.remove(callback, function () {
 +                    console.log('[ERROR] deleteFile cleanup method invoked fail callback.');
 +                });
 +            }, // doesn't exist
 +                callback);
 +        };
 +        // deletes and re-creates the specified file
 +        var createFile = function (fileName, success, error) {
 +            deleteEntry(fileName, function () {
 +                root.getFile(fileName, {
 +                    create : true
 +                }, success, error);
 +            }, error);
 +        };
 +        // deletes and re-creates the specified directory
 +        var createDirectory = function (dirName, success, error) {
 +            deleteEntry(dirName, function () {
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, success, error);
 +            }, error);
 +        };
 +        var failed = function (done, msg, error) {
 +            var info = typeof msg == 'undefined' ? 'Unexpected error callback' : msg;
 +            expect(true).toFailWithMessage(info + '\n' + JSON.stringify(error));
 +            done();
 +        };
 +        var succeed = function (done, msg) {
 +            var info = typeof msg == 'undefined' ? 'Unexpected success callback' : msg;
 +            expect(true).toFailWithMessage(info);
 +            done();
 +        };
 +        var joinURL = function (base, extension) {
 +            if (base.charAt(base.length - 1) !== '/' && extension.charAt(0) !== '/') {
 +                return base + '/' + extension;
 +            }
 +            if (base.charAt(base.length - 1) === '/' && extension.charAt(0) === '/') {
 +                return base + exension.substring(1);
 +            }
 +            return base + extension;
 +        };
 +        describe('FileError object', function () {
 +            it("file.spec.1 should define FileError constants", function () {
 +                expect(FileError.NOT_FOUND_ERR).toBe(1);
 +                expect(FileError.SECURITY_ERR).toBe(2);
 +                expect(FileError.ABORT_ERR).toBe(3);
 +                expect(FileError.NOT_READABLE_ERR).toBe(4);
 +                expect(FileError.ENCODING_ERR).toBe(5);
 +                expect(FileError.NO_MODIFICATION_ALLOWED_ERR).toBe(6);
 +                expect(FileError.INVALID_STATE_ERR).toBe(7);
 +                expect(FileError.SYNTAX_ERR).toBe(8);
 +                expect(FileError.INVALID_MODIFICATION_ERR).toBe(9);
 +                expect(FileError.QUOTA_EXCEEDED_ERR).toBe(10);
 +                expect(FileError.TYPE_MISMATCH_ERR).toBe(11);
 +                expect(FileError.PATH_EXISTS_ERR).toBe(12);
 +            });
 +        });
 +        describe('LocalFileSystem', function () {
 +            it("file.spec.2 should define LocalFileSystem constants", function () {
 +                expect(LocalFileSystem.TEMPORARY).toBe(0);
 +                expect(LocalFileSystem.PERSISTENT).toBe(1);
 +            });
 +            describe('window.requestFileSystem', function () {
 +                it("file.spec.3 should be defined", function () {
 +                    expect(window.requestFileSystem).toBeDefined();
 +                });
 +                it("file.spec.4 should be able to retrieve a PERSISTENT file system", function (done) {
 +                    var win = function (fileSystem) {
 +                        expect(fileSystem).toBeDefined();
 +                        expect(fileSystem.name).toBeDefined();
 +                        expect(fileSystem.name).toBe("persistent");
 +                        expect(fileSystem.root).toBeDefined();
 +                        expect(fileSystem.root.filesystem).toBeDefined();
 +                        // Shouldn't use cdvfile by default.
 +                        expect(fileSystem.root.toURL()).not.toMatch(/^cdvfile:/);
 +                        // All DirectoryEntry URLs should always have a trailing slash.
 +                        expect(fileSystem.root.toURL()).toMatch(/\/$/);
 +                        done();
 +                    };
 +                    // retrieve PERSISTENT file system
 +                    window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, win, failed.bind(null, done, 'window.requestFileSystem - Error retrieving PERSISTENT file system'));
 +                });
 +                it("file.spec.5 should be able to retrieve a TEMPORARY file system", function (done) {
 +                    var win = function (fileSystem) {
 +                        expect(fileSystem).toBeDefined();
 +                        expect(fileSystem.name).toBeDefined();
 +                        expect(fileSystem.name).toBe("temporary");
 +                        expect(fileSystem.root).toBeDefined();
 +                        expect(fileSystem.root.filesystem).toBeDefined();
 +                        expect(fileSystem.root.filesystem).toBe(fileSystem);
 +                        done();
 +                    };
 +                    //retrieve TEMPORARY file system
 +                    window.requestFileSystem(LocalFileSystem.TEMPORARY, 0, win, failed.bind(null, done, 'window.requestFileSystem - Error retrieving TEMPORARY file system'));
 +                });
 +                it("file.spec.6 should error if you request a file system that is too large", function (done) {
 +                    var fail = function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.QUOTA_EXCEEDED_ERR);
 +                        done();
 +                    };
 +                    //win = createWin('window.requestFileSystem');
 +                    // Request the file system
 +                    window.requestFileSystem(LocalFileSystem.TEMPORARY, 1000000000000000, failed.bind(null, done, 'window.requestFileSystem - Error retrieving TEMPORARY file system'), fail);
 +                });
 +                it("file.spec.7 should error out if you request a file system that does not exist", function (done) {
 +                    var fail = function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.SYNTAX_ERR);
 +                        done();
 +                    };
 +                    // Request the file system
 +                    window.requestFileSystem(-1, 0, succeed.bind(null, done, 'window.requestFileSystem'), fail);
 +                });
 +            });
 +            describe('window.resolveLocalFileSystemURL', function () {
 +                it("file.spec.8 should be defined", function () {
 +                    expect(window.resolveLocalFileSystemURL).toBeDefined();
 +                });
 +                it("file.spec.9 should resolve a valid file name", function (done) {
 +                    var fileName = 'file.spec.9';
 +                    var win = function (fileEntry) {
 +                        expect(fileEntry).toBeDefined();
 +                        expect(fileEntry.name).toCanonicallyMatch(fileName);
 +                        expect(fileEntry.toURL()).not.toMatch(/^cdvfile:/, 'should not use cdvfile URL');
 +                        expect(fileEntry.toURL()).not.toMatch(/\/$/, 'URL should not end with a slash');
 +                        // Clean-up
 +                        deleteEntry(fileName);
 +                        //End
 +                        done();
 +                    };
 +                    createFile(fileName, function (entry) {
 +                        window.resolveLocalFileSystemURL(entry.toURL(), win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - Error resolving file URL: ' + entry.toURL()));
 +                    }, failed.bind(null, done, 'createFile - Error creating file: ' + fileName), failed.bind(null, done, 'createFile - Error creating file: ' + fileName));
 +                });
 +                it("file.spec.9.5 should resolve a directory", function (done) {
 +                    var fileName = 'file.spec.9.5';
 +                    var win = function (fileEntry) {
 +                        expect(fileEntry).toBeDefined();
 +                        expect(fileEntry.name).toCanonicallyMatch(fileName);
 +                        expect(fileEntry.toURL()).not.toMatch(/^cdvfile:/, 'should not use cdvfile URL');
 +                        if (cordova.platformId === 'windowsphone') {
 +                            expect(fileEntry.toURL()).not.toMatch(/\/$/, 'URL end with a slash');
 +                        } else {
 +                            expect(fileEntry.toURL()).toMatch(/\/$/, 'URL end with a slash');
 +                        }
 +                        // cleanup
 +                        deleteEntry(fileName);
 +                        done();
 +                    };
 +                    function gotDirectory(entry) {
 +                        // lookup file system entry
 +                        window.resolveLocalFileSystemURL(entry.toURL(), win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - Error resolving directory URL: ' + entry.toURL()));
 +                    }
 +                    createDirectory(fileName, gotDirectory, failed.bind(null, done, 'createDirectory - Error creating directory: ' + fileName), failed.bind(null, done, 'createDirectory - Error creating directory: ' + fileName));
 +                });
 +                it("file.spec.10 resolve valid file name with parameters", function (done) {
 +                    var fileName = "resolve.file.uri.params",
 +                    win = function (fileEntry) {
 +                        expect(fileEntry).toBeDefined();
 +                        if (fileEntry.toURL().toLowerCase().substring(0, 10) === "cdvfile://") {
 +                            expect(fileEntry.fullPath).toBe("/" + fileName + "?1234567890");
 +                        }
 +                        expect(fileEntry.name).toBe(fileName);
 +                        // cleanup
 +                        deleteEntry(fileName);
 +                        done();
 +                    };
 +                    // create a new file entry
 +                    createFile(fileName, function (entry) {
 +                        window.resolveLocalFileSystemURL(entry.toURL() + "?1234567890", win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - Error resolving file URI: ' + entry.toURL()));
 +                    }, failed.bind(null, done, 'createFile - Error creating file: ' + fileName));
 +                });
 +                it("file.spec.11 should error (NOT_FOUND_ERR) when resolving (non-existent) invalid file name", function (done) {
 +                    var fileName = cordova.platformId === 'windowsphone' ? root.toURL() + "/" + "this.is.not.a.valid.file.txt" : joinURL(root.toURL(), "this.is.not.a.valid.file.txt");
 +                    fail = function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                        done();
 +                    };
 +                    // lookup file system entry
 +                    window.resolveLocalFileSystemURL(fileName, succeed.bind(null, done, 'window.resolveLocalFileSystemURL - Error unexpected callback resolving file URI: ' + fileName), fail);
 +                });
 +                it("file.spec.12 should error (ENCODING_ERR) when resolving invalid URI with leading /", function (done) {
 +                    var fileName = "/this.is.not.a.valid.url",
 +                    fail = function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.ENCODING_ERR);
 +                        done();
 +                    };
 +                    // lookup file system entry
 +                    window.resolveLocalFileSystemURL(fileName, succeed.bind(null, done, 'window.resolveLocalFileSystemURL - Error unexpected callback resolving file URI: ' + fileName), fail);
 +                });
 +            });
 +        });
 +        //LocalFileSystem
 +        describe('Metadata interface', function () {
 +            it("file.spec.13 should exist and have the right properties", function () {
 +                var metadata = new Metadata();
 +                expect(metadata).toBeDefined();
 +                expect(metadata.modificationTime).toBeDefined();
 +            });
 +        });
 +        describe('Flags interface', function () {
 +            it("file.spec.14 should exist and have the right properties", function () {
 +                var flags = new Flags(false, true);
 +                expect(flags).toBeDefined();
 +                expect(flags.create).toBeDefined();
 +                expect(flags.create).toBe(false);
 +                expect(flags.exclusive).toBeDefined();
 +                expect(flags.exclusive).toBe(true);
 +            });
 +        });
 +        describe('FileSystem interface', function () {
 +            it("file.spec.15 should have a root that is a DirectoryEntry", function (done) {
 +                var win = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(false);
 +                    expect(entry.isDirectory).toBe(true);
 +                    expect(entry.name).toBeDefined();
 +                    expect(entry.fullPath).toBeDefined();
 +                    expect(entry.getMetadata).toBeDefined();
 +                    expect(entry.moveTo).toBeDefined();
 +                    expect(entry.copyTo).toBeDefined();
 +                    expect(entry.toURL).toBeDefined();
 +                    expect(entry.remove).toBeDefined();
 +                    expect(entry.getParent).toBeDefined();
 +                    expect(entry.createReader).toBeDefined();
 +                    expect(entry.getFile).toBeDefined();
 +                    expect(entry.getDirectory).toBeDefined();
 +                    expect(entry.removeRecursively).toBeDefined();
 +                    done();
 +                };
 +                window.resolveLocalFileSystemURL(root.toURL(), win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - Error resolving file URI: ' + root.toURL()));
 +            });
 +        });
 +        describe('DirectoryEntry', function () {
 +            it("file.spec.16 getFile: get Entry for file that does not exist", function (done) {
 +                var fileName = "de.no.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                    done();
 +                };
 +                // create:false, exclusive:false, file does not exist
 +                root.getFile(fileName, {
 +                    create : false
 +                }, succeed.bind(null, done, 'root.getFile - Error unexpected callback, file should not exists: ' + fileName), fail);
 +            });
 +            it("file.spec.17 getFile: create new file", function (done) {
 +                var fileName = "de.create.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                win = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(true);
 +                    expect(entry.isDirectory).toBe(false);
 +                    expect(entry.name).toCanonicallyMatch(fileName);
 +                    expect(entry.fullPath).toCanonicallyMatch(filePath);
 +                    // cleanup
 +                    entry.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:false, file does not exist
 +                root.getFile(fileName, {
 +                    create : true
 +                }, win, succeed.bind(null, done, 'root.getFile - Error unexpected callback, file should not exists: ' + fileName));
 +            });
 +            it("file.spec.18 getFile: create new file (exclusive)", function (done) {
 +                var fileName = "de.create.exclusive.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                win = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(true);
 +                    expect(entry.isDirectory).toBe(false);
 +                    expect(entry.name).toBe(fileName);
 +                    expect(entry.fullPath).toCanonicallyMatch(filePath);
 +                    // cleanup
 +                    entry.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:true, file does not exist
 +                root.getFile(fileName, {
 +                    create : true,
 +                    exclusive : true
 +                }, win, failed.bind(null, done, 'root.getFile - Error creating file: ' + fileName));
 +            });
 +            it("file.spec.19 getFile: create file that already exists", function (done) {
 +                var fileName = "de.create.existing.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                getFile = function (file) {
 +                    // create:true, exclusive:false, file exists
 +                    root.getFile(fileName, {
 +                        create : true
 +                    }, win, failed.bind(null, done, 'root.getFile - Error creating file: ' + fileName));
 +                },
 +                win = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(true);
 +                    expect(entry.isDirectory).toBe(false);
 +                    expect(entry.name).toCanonicallyMatch(fileName);
 +                    expect(entry.fullPath).toCanonicallyMatch(filePath);
 +                    // cleanup
 +                    entry.remove(null, fail);
 +                    done();
 +                };
 +                // create file to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, getFile, fail);
 +            });
 +            it("file.spec.20 getFile: create file that already exists (exclusive)", function (done) {
 +                var fileName = "de.create.exclusive.existing.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                existingFile,
 +                getFile = function (file) {
 +                    existingFile = file;
 +                    // create:true, exclusive:true, file exists
 +                    root.getFile(fileName, {
 +                        create : true,
 +                        exclusive : true
 +                    }, succeed.bind(null, done, 'root.getFile - getFile function - Error unexpected callback, file should exists: ' + fileName), fail);
 +                },
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.PATH_EXISTS_ERR);
 +                    // cleanup
 +                    existingFile.remove(null, null);
 +                    done();
 +                };
 +                // create file to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, getFile, failed.bind(null, done, 'root.getFile - Error creating file: ' + fileName));
 +            });
 +            it("file.spec.21 DirectoryEntry.getFile: get Entry for existing file", function (done) {
 +                var fileName = "de.get.file",
 +                filePath = joinURL(root.fullPath, fileName),
 +                win = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(true);
 +                    expect(entry.isDirectory).toBe(false);
 +                    expect(entry.name).toCanonicallyMatch(fileName);
 +                    expect(entry.fullPath).toCanonicallyMatch(filePath);
 +                    expect(entry.filesystem).toBeDefined();
 +                    expect(entry.filesystem).toBe(root.filesystem);
 +                    //clean up
 +                    entry.remove(null, null);
 +                    done();
 +                },
 +                getFile = function (file) {
 +                    // create:false, exclusive:false, file exists
 +                    root.getFile(fileName, {
 +                        create : false
 +                    }, win, failed.bind(null, done, 'root.getFile - Error getting file entry: ' + fileName));
 +                };
 +                // create file to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, getFile, failed.bind(null, done, 'root.getFile - Error creating file: ' + fileName));
 +            });
 +            it("file.spec.22 DirectoryEntry.getFile: get FileEntry for invalid path", function (done) {
 +                var fileName = "de:invalid:path",
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.ENCODING_ERR);
 +                    done();
 +                };
 +                // create:false, exclusive:false, invalid path
 +                root.getFile(fileName, {
 +                    create : false
 +                }, succeed.bind(null, done, 'root.getFile - Error unexpected callback, file should not exists: ' + fileName), fail);
 +            });
 +            it("file.spec.23 DirectoryEntry.getDirectory: get Entry for directory that does not exist", function (done) {
 +                var dirName = "de.no.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                    done();
 +                };
 +                // create:false, exclusive:false, directory does not exist
 +                root.getDirectory(dirName, {
 +                    create : false
 +                }, succeed.bind(null, done, 'root.getDirectory - Error unexpected callback, directory should not exists: ' + dirName), fail);
 +            });
 +            it("file.spec.24 DirectoryEntry.getDirectory: create new dir with space then resolveLocalFileSystemURL", function (done) {
 +                var dirName = "de create dir",
 +                dirPath = joinURL(root.fullPath, encodeURIComponent(dirName)),
 +                getDir = function (dirEntry) {
 +                    expect(dirEntry.filesystem).toBeDefined();
 +                    expect(dirEntry.filesystem).toBe(root.filesystem);
 +                    var dirURI = dirEntry.toURL();
 +                    // now encode URI and try to resolve
 +                    window.resolveLocalFileSystemURL(dirURI, win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - getDir function - Error resolving directory: ' + dirURI));
 +                },
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(joinURL(root.fullPath, dirName));
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:false, directory does not exist
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, getDir, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            // This test is excluded, and should probably be removed. Filesystem
 +            // should always be properly encoded URLs, and *not* raw paths, and it
 +            // doesn't make sense to double-encode the URLs and expect that to be
 +            // handled by the implementation.
 +            // If a particular platform uses paths internally rather than URLs, // then that platform should careful to pass them correctly to its
 +            // backend.
 +            xit("file.spec.25 DirectoryEntry.getDirectory: create new dir with space resolveLocalFileSystemURL with encoded URI", function (done) {
 +                var dirName = "de create dir2",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                getDir = function (dirEntry) {
 +                    var dirURI = dirEntry.toURL();
 +                    // now encode URI and try to resolve
 +                    window.resolveLocalFileSystemURL(encodeURI(dirURI), win, failed.bind(null, done, 'window.resolveLocalFileSystemURL - getDir function - Error resolving directory: ' + dirURI));
 +                },
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(dirPath);
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:false, directory does not exist
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, getDir, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.26 DirectoryEntry.getDirectory: create new directory", function (done) {
 +                var dirName = "de.create.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(dirPath);
 +                    expect(directory.filesystem).toBeDefined();
 +                    expect(directory.filesystem).toBe(root.filesystem);
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:false, directory does not exist
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, win, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.27 DirectoryEntry.getDirectory: create new directory (exclusive)", function (done) {
 +                var dirName = "de.create.exclusive.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(dirPath);
 +                    expect(directory.filesystem).toBeDefined();
 +                    expect(directory.filesystem).toBe(root.filesystem);
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create:true, exclusive:true, directory does not exist
 +                root.getDirectory(dirName, {
 +                    create : true,
 +                    exclusive : true
 +                }, win, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.28 DirectoryEntry.getDirectory: create directory that already exists", function (done) {
 +                var dirName = "de.create.existing.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(dirPath);
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create directory to kick off it
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function () {
 +                    root.getDirectory(dirName, {
 +                        create : true
 +                    }, win, failed.bind(null, done, 'root.getDirectory - Error creating existent second directory : ' + dirName));
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.29 DirectoryEntry.getDirectory: create directory that already exists (exclusive)", function (done) {
 +                var dirName = "de.create.exclusive.existing.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                existingDir,
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.PATH_EXISTS_ERR);
 +                    // cleanup
 +                    existingDir.remove(null, null);
 +                    done();
 +                };
 +                // create directory to kick off it
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function (directory) {
 +                    existingDir = directory;
 +                    // create:true, exclusive:true, directory exists
 +                    root.getDirectory(dirName, {
 +                        create : true,
 +                        exclusive : true
 +                    }, failed.bind(null, done, 'root.getDirectory - Unexpected success callback, second directory should not be created : ' + dirName), fail);
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.30 DirectoryEntry.getDirectory: get Entry for existing directory", function (done) {
 +                var dirName = "de.get.dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                win = function (directory) {
 +                    expect(directory).toBeDefined();
 +                    expect(directory.isFile).toBe(false);
 +                    expect(directory.isDirectory).toBe(true);
 +                    expect(directory.name).toCanonicallyMatch(dirName);
 +                    expect(directory.fullPath).toCanonicallyMatch(dirPath);
 +                    // cleanup
 +                    directory.remove(null, null);
 +                    done();
 +                };
 +                // create directory to kick it off
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function () {
 +                    root.getDirectory(dirName, {
 +                        create : false
 +                    }, win, failed.bind(null, done, 'root.getDirectory - Error getting directory entry : ' + dirName));
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.31 DirectoryEntry.getDirectory: get DirectoryEntry for invalid path", function (done) {
 +                var dirName = "de:invalid:path",
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.ENCODING_ERR);
 +                    done();
 +                };
 +                // create:false, exclusive:false, invalid path
 +                root.getDirectory(dirName, {
 +                    create : false
 +                }, succeed.bind(null, done, 'root.getDirectory - Unexpected success callback, directory should not exists: ' + dirName), fail);
 +            });
 +            it("file.spec.32 DirectoryEntry.getDirectory: get DirectoryEntry for existing file", function (done) {
 +                var fileName = "de.existing.file",
 +                existingFile,
 +                filePath = joinURL(root.fullPath, fileName),
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.TYPE_MISMATCH_ERR);
 +                    // cleanup
 +                    existingFile.remove(null, null);
 +                    done();
 +                };
 +                // create file to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, function (file) {
 +                    existingFile = file;
 +                    root.getDirectory(fileName, {
 +                        create : false
 +                    }, succeed.bind(null, done, 'root.getDirectory - Unexpected success callback, directory should not exists: ' + fileName), fail);
 +                }, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.33 DirectoryEntry.getFile: get FileEntry for existing directory", function (done) {
 +                var dirName = "de.existing.dir",
 +                existingDir,
 +                dirPath = joinURL(root.fullPath, dirName),
 +                fail = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.TYPE_MISMATCH_ERR);
 +                    // cleanup
 +                    existingDir.remove(null, null);
 +                    done();
 +                };
 +                // create directory to kick off it
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function (directory) {
 +                    existingDir = directory;
 +                    root.getFile(dirName, {
 +                        create : false
 +                    }, succeed.bind(null, done, 'root.getFile - Unexpected success callback, file should not exists: ' + dirName), fail);
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.34 DirectoryEntry.removeRecursively on directory", function (done) {
 +                var dirName = "de.removeRecursively",
 +                subDirName = "dir",
 +                dirPath = joinURL(root.fullPath, dirName),
 +                subDirPath = joinURL(dirPath, subDirName),
 +                dirExists = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                    done();
 +                };
 +                // create a new directory entry to kick off it
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function (entry) {
 +                    entry.getDirectory(subDirName, {
 +                        create : true
 +                    }, function (dir) {
 +                        entry.removeRecursively(function () {
 +                            root.getDirectory(dirName, {
 +                                create : false
 +                            }, succeed.bind(null, done, 'root.getDirectory - Unexpected success callback, directory should not exists: ' + dirName), dirExists);
 +                        }, failed.bind(null, done, 'entry.removeRecursively - Error removing directory recursively : ' + dirName));
 +                    }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + subDirName));
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.35 createReader: create reader on existing directory", function () {
 +                // create reader for root directory
 +                var reader = root.createReader();
 +                expect(reader).toBeDefined();
 +                expect(typeof reader.readEntries).toBe('function');
 +            });
 +            it("file.spec.36 removeRecursively on root file system", function (done) {
 +                var remove = function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.NO_MODIFICATION_ALLOWED_ERR);
 +                    done();
 +                };
 +                // remove root file system
 +                root.removeRecursively(succeed.bind(null, done, 'root.removeRecursively - Unexpected success callback, root cannot be removed'), remove);
 +            });
 +        });
 +        describe('DirectoryReader interface', function () {
 +            describe("readEntries", function () {
 +                it("file.spec.37 should read contents of existing directory", function (done) {
 +                    var reader,
 +                    win = function (entries) {
 +                        expect(entries).toBeDefined();
 +                        expect(entries instanceof Array).toBe(true);
 +                        done();
 +                    };
 +                    // create reader for root directory
 +                    reader = root.createReader();
 +                    // read entries
 +                    reader.readEntries(win, failed.bind(null, done, 'reader.readEntries - Error reading entries'));
 +                });
 +                it("file.spec.37.1 should read contents of existing directory", function (done) {
 +                    var dirName = 'readEntries.dir',
 +                    fileName = 'readeEntries.file';
 +                    root.getDirectory(dirName, {
 +                        create : true
 +                    }, function (directory) {
 +                        directory.getFile(fileName, {
 +                            create : true
 +                        }, function (fileEntry) {
 +                            var reader = directory.createReader();
 +                            reader.readEntries(function (entries) {
 +                                expect(entries).toBeDefined();
 +                                expect(entries instanceof Array).toBe(true);
 +                                expect(entries.length).toBe(1);
 +                                expect(entries[0].fullPath).toCanonicallyMatch(fileEntry.fullPath);
 +                                expect(entries[0].filesystem).not.toBe(null);
 +                                expect(entries[0].filesystem instanceof FileSystem).toBe(true);
 +                                // cleanup
 +                                directory.removeRecursively(null, null);
 +                                done();
 +                            }, failed.bind(null, done, 'reader.readEntries - Error reading entries from directory: ' + dirName));
 +                        }, failed.bind(null, done, 'directory.getFile - Error creating file : ' + fileName));
 +                    }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +                });
 +                it("file.spec.109 should return an empty entry list on the second call", function (done) {
 +                    var reader,
 +                    fileName = 'test109.txt';
 +                    // Add a file to ensure the root directory is non-empty and then read the contents of the directory.
 +                    root.getFile(fileName, {
 +                        create : true
 +                    }, function (entry) {
 +                        reader = root.createReader();
 +                        //First read
 +                        reader.readEntries(function (entries) {
 +                            expect(entries).toBeDefined();
 +                            expect(entries instanceof Array).toBe(true);
 +                            expect(entries.length).not.toBe(0);
 +                            //Second read
 +                            reader.readEntries(function (entries_) {
 +                                expect(entries_).toBeDefined();
 +                                expect(entries_ instanceof Array).toBe(true);
 +                                expect(entries_.length).toBe(0);
 +                                //Clean up
 +                                entry.remove();
 +                                done();
 +                            }, failed.bind(null, done, 'reader.readEntries - Error during SECOND reading of entries from [root] directory'));
 +                        }, failed.bind(null, done, 'reader.readEntries - Error during FIRST reading of entries from [root] directory'));
 +                    }, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +                });
 +            });
 +            it("file.spec.38 should read contents of directory that has been removed", function (done) {
 +                var dirName = "de.createReader.notfound",
 +                dirPath = joinURL(root.fullPath, dirName);
 +                // create a new directory entry to kick off it
 +                root.getDirectory(dirName, {
 +                    create : true
 +                }, function (directory) {
 +                    directory.removeRecursively(function () {
 +                        var reader = directory.createReader();
 +                        reader.readEntries(succeed.bind(null, done, 'reader.readEntries - Unexpected success callback, it should not read entries from deleted dir: ' + dirName), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                            root.getDirectory(dirName, {
 +                                create : false
 +                            }, succeed.bind(null, done, 'root.getDirectory - Unexpected success callback, it should not get deleted directory: ' + dirName), function (err) {
 +                                expect(err).toBeDefined();
 +                                expect(err).toBeFileError(FileError.NOT_FOUND_ERR);
 +                                done();
 +                            });
 +                        });
 +                    }, failed.bind(null, done, 'directory.removeRecursively - Error removing directory recursively : ' + dirName));
 +                }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dirName));
 +            });
 +        });
 +        //DirectoryReader interface
 +        describe('File', function () {
 +            it("file.spec.39 constructor should be defined", function () {
 +                expect(File).toBeDefined();
 +                expect(typeof File).toBe('function');
 +            });
 +            it("file.spec.40 should be define File attributes", function () {
 +                var file = new File();
 +                expect(file.name).toBeDefined();
 +                expect(file.type).toBeDefined();
 +                expect(file.lastModifiedDate).toBeDefined();
 +                expect(file.size).toBeDefined();
 +            });
 +        });
 +        //File
 +        describe('FileEntry', function () {
 +            it("file.spec.41 should be define FileEntry methods", function (done) {
 +                var fileName = "fe.methods",
 +                testFileEntry = function (fileEntry) {
 +                    expect(fileEntry).toBeDefined();
 +                    expect(typeof fileEntry.createWriter).toBe('function');
 +                    expect(typeof fileEntry.file).toBe('function');
 +                    // cleanup
 +                    fileEntry.remove(null, null);
 +                    done();
 +                };
 +                // create a new file entry to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, testFileEntry, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.42 createWriter should return a FileWriter object", function (done) {
 +                var fileName = "fe.createWriter",
 +                testFile,
 +                testWriter = function (writer) {
 +                    expect(writer).toBeDefined();
 +                    expect(writer instanceof FileWriter).toBe(true);
 +                    // cleanup
 +                    testFile.remove(null, null);
 +                    done();
 +                };
 +                // create a new file entry to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, function (fileEntry) {
 +                    testFile = fileEntry;
 +                    fileEntry.createWriter(testWriter, failed.bind(null, done, 'fileEntry.createWriter - Error creating Writer from entry'));
 +                }, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.43 file should return a File object", function (done) {
 +                var fileName = "fe.file",
 +                newFile,
 +                testFile = function (file) {
 +                    expect(file).toBeDefined();
 +                    expect(file instanceof File).toBe(true);
 +                    // cleanup
 +                    newFile.remove(null, null);
 +                    done();
 +                };
 +                // create a new file entry to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, function (fileEntry) {
 +                    newFile = fileEntry;
 +                    fileEntry.file(testFile, failed.bind(null, done, 'fileEntry.file - Error reading file using fileEntry: ' + fileEntry.name));
 +                }, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.44 file: on File that has been removed", function (done) {
 +                var fileName = "fe.no.file";
 +                // create a new file entry to kick off it
 +                root.getFile(fileName, {
 +                    create : true
 +                }, function (fileEntry) {
 +                    fileEntry.remove(function () {
 +                        fileEntry.file(succeed.bind(null, done, 'fileEntry.file - Unexpected success callback, file it should not be created from removed entry'), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                            done();
 +                        });
 +                    }, failed.bind(null, done, 'fileEntry.remove - Error removing entry : ' + fileName));
 +                }, failed.bind(null, done, 'root.getFile - Error creating file : ' + fileName));
 +            });
 +        });
 +        //FileEntry
 +        describe('Entry', function () {
 +            it("file.spec.45 Entry object", function (done) {
 +                var fileName = "entry",
 +                fullPath = joinURL(root.fullPath, fileName),
 +                winEntry = function (entry) {
 +                    expect(entry).toBeDefined();
 +                    expect(entry.isFile).toBe(true);
 +                    expect(entry.isDirectory).toBe(false);
 +                    expect(entry.name).toCanonicallyMatch(fileName);
 +                    expect(entry.fullPath).toCanonicallyMatch(fullPath);
 +                    expect(typeof entry.getMetadata).toBe('function');
 +                    expect(typeof entry.setMetadata).toBe('function');
 +                    expect(typeof entry.moveTo).toBe('function');
 +                    expect(typeof entry.copyTo).toBe('function');
 +                    expect(typeof entry.toURL).toBe('function');
 +                    expect(typeof entry.remove).toBe('function');
 +                    expect(typeof entry.getParent).toBe('function');
 +                    expect(typeof entry.createWriter).toBe('function');
 +                    expect(typeof entry.file).toBe('function');
 +                    // Clean up
 +                    deleteEntry(fileName);
 +                    done();
 +                };
 +                // create a new file entry
 +                createFile(fileName, winEntry, failed.bind(null, done, 'createFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.46 Entry.getMetadata on file", function (done) {
 +                var fileName = "entry.metadata.file";
 +                // create a new file entry
 +                createFile(fileName, function (entry) {
 +                    entry.getMetadata(function (metadata) {
 +                        expect(metadata).toBeDefined();
 +                        expect(metadata.modificationTime instanceof Date).toBe(true);
 +                        expect(typeof metadata.size).toBe("number");
 +                        // cleanup
 +                        deleteEntry(fileName);
 +                        done();
 +                    }, failed.bind(null, done, 'entry.getMetadata - Error getting metadata from entry : ' + fileName));
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.47 Entry.getMetadata on directory", function (done) {
 +                var dirName = "entry.metadata.dir";
 +                // create a new directory entry
 +                createDirectory(dirName, function (entry) {
 +                    entry.getMetadata(function (metadata) {
 +                        expect(metadata).toBeDefined();
 +                        expect(metadata.modificationTime instanceof Date).toBe(true);
 +                        expect(typeof metadata.size).toBe("number");
 +                        expect(metadata.size).toBe(0);
 +                        // cleanup
 +                        deleteEntry(dirName);
 +                        done();
 +                    }, failed.bind(null, done, 'entry.getMetadata - Error getting metadata from entry : ' + dirName));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.48 Entry.getParent on file in root file system", function (done) {
 +                var fileName = "entry.parent.file",
 +                rootPath = root.fullPath;
 +                // create a new file entry
 +                createFile(fileName, function (entry) {
 +                    entry.getParent(function (parent) {
 +                        expect(parent).toBeDefined();
 +                        expect(parent.fullPath).toCanonicallyMatch(rootPath);
 +                        // cleanup
 +                        deleteEntry(fileName);
 +                        done();
 +                    }, failed.bind(null, done, 'entry.getParent - Error getting parent directory of file : ' + fileName));
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.49 Entry.getParent on directory in root file system", function (done) {
 +                var dirName = "entry.parent.dir",
 +                rootPath = root.fullPath;
 +                // create a new directory entry
 +                createDirectory(dirName, function (entry) {
 +                    entry.getParent(function (parent) {
-                         //alert("parent: "+JSON.stringify(parent));
 +                        expect(parent).toBeDefined();
 +                        expect(parent.fullPath).toCanonicallyMatch(rootPath);
 +                        // cleanup
 +                        deleteEntry(dirName);
 +                        done();
 +                    }, failed.bind(null, done, 'entry.getParent - Error getting parent directory of directory : ' + dirName));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.50 Entry.getParent on root file system", function (done) {
 +                var rootPath = root.fullPath,
 +                winParent = function (parent) {
 +                    expect(parent).toBeDefined();
 +                    expect(parent.fullPath).toCanonicallyMatch(rootPath);
 +                    done();
 +                };
 +                // create a new directory entry
 +                root.getParent(winParent, failed.bind(null, done, 'root.getParent - Error getting parent directory of root'));
 +            });
 +            it("file.spec.51 Entry.toURL on file", function (done) {
 +                var fileName = "entry.uri.file",
 +                rootPath = root.fullPath,
 +                winURI = function (entry) {
 +                    var uri = entry.toURL();
 +                    expect(uri).toBeDefined();
 +                    expect(uri.indexOf(rootPath)).not.toBe(-1);
 +                    // cleanup
 +                    deleteEntry(fileName);
 +                    done();
 +                };
 +                // create a new file entry
 +                createFile(fileName, winURI, failed.bind(null, done, 'createFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.52 Entry.toURL on directory", function (done) {
 +                var dirName_1 = "num 1",
 +                dirName_2 = "num 2",
 +                rootPath = root.fullPath;
 +                createDirectory(dirName_1, function (entry) {
 +                    entry.getDirectory(dirName_2, {
 +                        create : true
 +                    }, function (entryFile) {
 +                        var uri = entryFile.toURL();
 +                        expect(uri).toBeDefined();
 +                        expect(uri).toContain('/num%201/num%202/');
 +                        expect(uri.indexOf(rootPath)).not.toBe(-1);
 +                        // cleanup
 +                        deleteEntry(dirName_1);
 +                        done();
 +                    }, failed.bind(null, done, 'entry.getDirectory - Error creating directory : ' + dirName_2));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName_1));
 +            });
 +            it("file.spec.53 Entry.remove on file", function (done) {
 +                var fileName = "entr .rm.file";
 +                // create a new file entry
 +                createFile(fileName, function (entry) {
 +                    expect(entry).toBeDefined();
 +                    entry.remove(function () {
 +                        root.getFile(fileName, null, succeed.bind(null, done, 'root.getFile - Unexpected success callback, it should not get deleted file : ' + fileName), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                            // cleanup
 +                            deleteEntry(fileName);
 +                            done();
 +                        });
 +                    }, failed.bind(null, done, 'entry.remove - Error removing entry : ' + fileName));
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + fileName));
 +            });
 +            it("file.spec.54 remove on empty directory", function (done) {
 +                var dirName = "entry.rm.dir";
 +                // create a new directory entry
 +                createDirectory(dirName, function (entry) {
 +                    expect(entry).toBeDefined();
 +                    entry.remove(function () {
 +                        root.getDirectory(dirName, null, succeed.bind(null, done, 'root.getDirectory - Unexpected success callback, it should not get deleted directory : ' + dirName), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                            // cleanup
 +                            deleteEntry(dirName);
 +                            done();
 +                        });
 +                    }, failed.bind(null, done, 'entry.remove - Error removing entry : ' + dirName));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.55 remove on non-empty directory", function (done) {
 +                var dirName = "ent y.rm.dir.not.empty",
 +                fileName = "re ove.txt",
 +                fullPath = joinURL(root.fullPath, dirName);
 +                // create a new directory entry
 +                createDirectory(dirName, function (entry) {
 +                    entry.getFile(fileName, {
 +                        create : true
 +                    }, function (fileEntry) {
 +                        entry.remove(succeed.bind(null, done, 'entry.remove - Unexpected success callback, it should not remove a directory that contains files : ' + dirName), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.INVALID_MODIFICATION_ERR);
 +                            root.getDirectory(dirName, null, function (entry) {
 +                                expect(entry).toBeDefined();
 +                                expect(entry.fullPath).toCanonicallyMatch(fullPath);
 +                                // cleanup
 +                                deleteEntry(dirName);
 +                                done();
 +                            }, failed.bind(null, done, 'root.getDirectory - Error getting directory : ' + dirName));
 +                        });
 +                    }, failed.bind(null, done, 'entry.getFile - Error creating file : ' + fileName + ' inside of ' + dirName));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName));
 +            });
 +            it("file.spec.56 remove on root file system", function (done) {
 +                // remove entry that doesn't exist
 +                root.remove(succeed.bind(null, done, 'entry.remove - Unexpected success callback, it should not remove entry that it does not exists'), function (error) {
 +                    expect(error).toBeDefined();
 +                    expect(error).toBeFileError(FileError.NO_MODIFICATION_ALLOWED_ERR);
 +                    done();
 +                });
 +            });
 +            it("file.spec.57 copyTo: file", function (done) {
 +                var file1 = "entry copy.file1",
 +                file2 = "entry copy.file2",
 +                fullPath = joinURL(root.fullPath, file2);
 +                // create a new file entry to kick off it
 +                deleteEntry(file2, function () {
 +                    createFile(file1, function (fileEntry) {
 +                        // copy file1 to file2
 +                        fileEntry.copyTo(root, file2, function (entry) {
 +                            expect(entry).toBeDefined();
 +                            expect(entry.isFile).toBe(true);
 +                            expect(entry.isDirectory).toBe(false);
 +                            expect(entry.fullPath).toCanonicallyMatch(fullPath);
 +                            expect(entry.name).toCanonicallyMatch(file2);
 +                            root.getFile(file2, {
 +                                create : false
 +                            }, function (entry2) {
 +                                expect(entry2).toBeDefined();
 +                                expect(entry2.isFile).toBe(true);
 +                                expect(entry2.isDirectory).toBe(false);
 +                                expect(entry2.fullPath).toCanonicallyMatch(fullPath);
 +                                expect(entry2.name).toCanonicallyMatch(file2);
 +                                // cleanup
 +                                deleteEntry(file1);
 +                                deleteEntry(file2);
 +                                done();
 +                            }, failed.bind(null, done, 'root.getFile - Error getting copied file : ' + file2));
 +                        }, failed.bind(null, done, 'fileEntry.copyTo - Error copying file : ' + file2));
 +                    }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +                }, failed.bind(null, done, 'deleteEntry - Error removing file : ' + file2));
 +            });
 +            it("file.spec.58 copyTo: file onto itself", function (done) {
 +                var file1 = "entry.copy.fos.file1";
 +                // create a new file entry to kick off it
 +                createFile(file1, function (entry) {
 +                    // copy file1 onto itself
 +                    entry.copyTo(root, null, succeed.bind(null, done, 'entry.copyTo - Unexpected success callback, it should not copy a null file'), function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.INVALID_MODIFICATION_ERR);
 +                        // cleanup
 +                        deleteEntry(file1);
 +                        done();
 +                    });
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +            });
 +            it("file.spec.59 copyTo: directory", function (done) {
 +                var file1 = "file1",
 +                srcDir = "entry.copy.srcDir",
 +                dstDir = "entry.copy.dstDir",
 +                dstPath = joinURL(root.fullPath, dstDir),
 +                filePath = joinURL(dstPath, file1);
 +                // create a new directory entry to kick off it
 +                deleteEntry(dstDir, function () {
 +                    createDirectory(srcDir, function (directory) {
 +                        // create a file within new directory
 +                        directory.getFile(file1, {
 +                            create : true
 +                        }, function () {
 +                            directory.copyTo(root, dstDir, function (directory) {
 +                                expect(directory).toBeDefined();
 +                                expect(directory.isFile).toBe(false);
 +                                expect(directory.isDirectory).toBe(true);
 +                                expect(directory.fullPath).toCanonicallyMatch(dstPath);
 +                                expect(directory.name).toCanonicallyMatch(dstDir);
 +                                root.getDirectory(dstDir, {
 +                                    create : false
 +                                }, function (dirEntry) {
 +                                    expect(dirEntry).toBeDefined();
 +                                    expect(dirEntry.isFile).toBe(false);
 +                                    expect(dirEntry.isDirectory).toBe(true);
 +                                    expect(dirEntry.fullPath).toCanonicallyMatch(dstPath);
 +                                    expect(dirEntry.name).toCanonicallyMatch(dstDir);
 +                                    dirEntry.getFile(file1, {
 +                                        create : false
 +                                    }, function (fileEntry) {
 +                                        expect(fileEntry).toBeDefined();
 +                                        expect(fileEntry.isFile).toBe(true);
 +                                        expect(fileEntry.isDirectory).toBe(false);
 +                                        expect(fileEntry.fullPath).toCanonicallyMatch(filePath);
 +                                        expect(fileEntry.name).toCanonicallyMatch(file1);
 +                                        // cleanup
 +                                        deleteEntry(srcDir);
 +                                        deleteEntry(dstDir);
 +                                        done();
 +                                    }, failed.bind(null, done, 'dirEntry.getFile - Error getting file : ' + file1));
 +                                }, failed.bind(null, done, 'root.getDirectory - Error getting copied directory : ' + dstDir));
 +                            }, failed.bind(null, done, 'directory.copyTo - Error copying directory : ' + srcDir + ' to :' + dstDir));
 +                        }, failed.bind(null, done, 'directory.getFile - Error creating file : ' + file1));
 +                    }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + srcDir));
 +                }, failed.bind(null, done, 'deleteEntry - Error removing directory : ' + dstDir));
 +            });
 +            it("file.spec.60 copyTo: directory to backup at same root directory", function (done) {
 +                var file1 = "file1",
 +                srcDir = "entry.copy srcDirSame",
 +                dstDir = "entry.copy srcDirSame-backup",
 +                dstPath = joinURL(root.fullPath, dstDir),
 +                filePath = joinURL(dstPath, file1);
 +                // create a new directory entry to kick off it
 +                deleteEntry(dstDir, function () {
 +                    createDirectory(srcDir, function (directory) {
 +                        directory.getFile(file1, {
 +                            create : true
 +                        }, function () {
 +                            directory.copyTo(root, dstDir, function (directory) {
 +                                expect(directory).toBeDefined();
 +                                expect(directory.isFile).toBe(false);
 +                                expect(directory.isDirectory).toBe(true);
 +                                expect(directory.fullPath).toCanonicallyMatch(dstPath);
 +                                expect(directory.name).toCanonicallyMatch(dstDir);
 +                                root.getDirectory(dstDir, {
 +                                    create : false
 +                                }, function (dirEntry) {
 +                                    expect(dirEntry).toBeDefined();
 +                                    expect(dirEntry.isFile).toBe(false);
 +                                    expect(dirEntry.isDirectory).toBe(true);
 +                                    expect(dirEntry.fullPath).toCanonicallyMatch(dstPath);
 +                                    expect(dirEntry.name).toCanonicallyMatch(dstDir);
 +                                    dirEntry.getFile(file1, {
 +                                        create : false
 +                                    }, function (fileEntry) {
 +                                        expect(fileEntry).toBeDefined();
 +                                        expect(fileEntry.isFile).toBe(true);
 +                                        expect(fileEntry.isDirectory).toBe(false);
 +                                        expect(fileEntry.fullPath).toCanonicallyMatch(filePath);
 +                                        expect(fileEntry.name).toCanonicallyMatch(file1);
 +                                        // cleanup
 +                                        deleteEntry(srcDir);
 +                                        deleteEntry(dstDir);
 +                                        done();
 +                                    }, failed.bind(null, done, 'dirEntry.getFile - Error getting file : ' + file1));
 +                                }, failed.bind(null, done, 'root.getDirectory - Error getting copied directory : ' + dstDir));
 +                            }, failed.bind(null, done, 'directory.copyTo - Error copying directory : ' + srcDir + ' to :' + dstDir));
 +                        }, failed.bind(null, done, 'directory.getFile - Error creating file : ' + file1));
 +                    }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + srcDir));
 +                }, failed.bind(null, done, 'deleteEntry - Error removing directory : ' + dstDir));
 +            });
 +            it("file.spec.61 copyTo: directory onto itself", function (done) {
 +                var file1 = "file1",
 +                srcDir = "entry.copy.dos.srcDir",
 +                srcPath = joinURL(root.fullPath, srcDir),
 +                filePath = joinURL(srcPath, file1);
 +                // create a new directory entry to kick off it
 +                createDirectory(srcDir, function (directory) {
 +                    // create a file within new directory
 +                    directory.getFile(file1, {
 +                        create : true
 +                    }, function (fileEntry) {
 +                        // copy srcDir onto itself
 +                        directory.copyTo(root, null, succeed.bind(null, done, 'directory.copyTo - Unexpected success callback, it should not copy file: ' + srcDir + ' to a null destination'), function (error) {
 +                            expect(error).toBeDefined();
 +                            expect(error).toBeFileError(FileError.INVALID_MODIFICATION_ERR);
 +                            root.getDirectory(srcDir, {
 +                                create : false
 +                            }, function (dirEntry) {
 +                                expect(dirEntry).toBeDefined();
 +                                expect(dirEntry.fullPath).toCanonicallyMatch(srcPath);
 +                                dirEntry.getFile(file1, {
 +                                    create : false
 +                                }, function (fileEntry) {
 +                                    expect(fileEntry).toBeDefined();
 +                                    expect(fileEntry.fullPath).toCanonicallyMatch(filePath);
 +                                    // cleanup
 +                                    deleteEntry(srcDir);
 +                                    done();
 +                                }, failed.bind(null, done, 'dirEntry.getFile - Error getting file : ' + file1));
 +                            }, failed.bind(null, done, 'root.getDirectory - Error getting directory : ' + srcDir));
 +                        });
 +                    }, failed.bind(null, done, 'directory.getFile - Error creating file : ' + file1));
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + srcDir));
 +            });
 +            it("file.spec.62 copyTo: directory into itself", function (done) {
 +                var srcDir = "entry.copy.dis.srcDir",
 +                dstDir = "entry.copy.dis.dstDir",
 +                srcPath = joinURL(root.fullPath, srcDir);
 +                // create a new directory entry to kick off it
 +                createDirectory(srcDir, function (directory) {
 +                    // copy source directory into itself
 +                    directory.copyTo(directory, dstDir, succeed.bind(null, done, 'directory.copyTo - Unexpected success callback, it should not copy a directory ' + srcDir + ' into itself'), function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.INVALID_MODIFICATION_ERR);
 +                        root.getDirectory(srcDir, {
 +                            create : false
 +                        }, function (dirEntry) {
 +                            // returning confirms existence so just check fullPath entry
 +                            expect(dirEntry).toBeDefined();
 +                            expect(dirEntry.fullPath).toCanonicallyMatch(srcPath);
 +                            // cleanup
 +                            deleteEntry(srcDir);
 +                            done();
 +                        }, failed.bind(null, done, 'root.getDirectory - Error getting directory : ' + srcDir));
 +                    });
 +                }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + srcDir));
 +            });
 +            it("file.spec.63 copyTo: directory that does not exist", function (done) {
 +                var file1 = "entry.copy.dnf.file1",
 +                dirName = 'dir-foo';
 +                createFile(file1, function (fileEntry) {
 +                    createDirectory(dirName, function (dirEntry) {
 +                        dirEntry.remove(function () {
 +                            fileEntry.copyTo(dirEntry, null, succeed.bind(null, done, 'fileEntry.copyTo - Unexpected success callback, it should not copy a file ' + file1 + ' into a removed directory'), function (error) {
 +                                expect(error).toBeDefined();
 +                                expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                                done();
 +                            });
 +                        }, failed.bind(null, done, 'dirEntry.remove - Error removing directory : ' + dirName));
 +                    }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + dirName));
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +            });
 +            it("file.spec.64 copyTo: invalid target name", function (done) {
 +                var file1 = "entry.copy.itn.file1",
 +                file2 = "bad:file:name";
 +                // create a new file entry
 +                createFile(file1, function (entry) {
 +                    // copy file1 to file2
 +                    entry.copyTo(root, file2, succeed.bind(null, done, 'entry.copyTo - Unexpected success callback, it should not copy a file ' + file1 + ' to an invalid file name: ' + file2), function (error) {
 +                        expect(error).toBeDefined();
 +                        expect(error).toBeFileError(FileError.ENCODING_ERR);
 +                        // cleanup
 +                        deleteEntry(file1);
 +                        done();
 +                    });
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +            });
 +            it("file.spec.65 moveTo: file to same parent", function (done) {
 +                var file1 = "entry.move.fsp.file1",
 +                file2 = "entry.move.fsp.file2",
 +                dstPath = joinURL(root.fullPath, file2);
 +                // create a new file entry to kick off it
 +                createFile(file1, function (entry) {
 +                    // move file1 to file2
 +                    entry.moveTo(root, file2, function (entry) {
 +                        expect(entry).toBeDefined();
 +                        expect(entry.isFile).toBe(true);
 +                        expect(entry.isDirectory).toBe(false);
 +                        expect(entry.fullPath).toCanonicallyMatch(dstPath);
 +                        expect(entry.name).toCanonicallyMatch(file2);
 +                        root.getFile(file2, {
 +                            create : false
 +                        }, function (fileEntry) {
 +                            expect(fileEntry).toBeDefined();
 +                            expect(fileEntry.fullPath).toCanonicallyMatch(dstPath);
 +                            root.getFile(file1, {
 +                                create : false
 +                            }, succeed.bind(null, done, 'root.getFile - Unexpected success callback, it should not get invalid or moved file: ' + file1), function (error) {
 +                                //expect(navigator.fileMgr.testFileExists(srcPath) === false, "original file should not exist.");
 +                                expect(error).toBeDefined();
 +                                expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                                // cleanup
 +                                deleteEntry(file1);
 +                                deleteEntry(file2);
 +                                done();
 +                            });
 +                        }, failed.bind(null, done, 'root.getFile - Error getting file : ' + file2));
 +                    }, failed.bind(null, done, 'entry.moveTo - Error moving file : ' + file1 + ' to root as: ' + file2));
 +                }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +            });
 +            it("file.spec.66 moveTo: file to new parent", function (done) {
 +                var file1 = "entry.move.fnp.file1",
 +                dir = "entry.move.fnp.dir",
 +                dstPath = joinURL(joinURL(root.fullPath, dir), file1);
 +                // ensure destination directory is cleaned up first
 +                deleteEntry(dir, function () {
 +                    // create a new file entry to kick off it
 +                    createFile(file1, function (entry) {
 +                        // create a parent directory to move file to
 +                        root.getDirectory(dir, {
 +                            create : true
 +                        }, function (directory) {
 +                            // move file1 to new directory
 +                            // move the file
 +                            entry.moveTo(directory, null, function (entry) {
 +                                expect(entry).toBeDefined();
 +                                expect(entry.isFile).toBe(true);
 +                                expect(entry.isDirectory).toBe(false);
 +                                expect(entry.fullPath).toCanonicallyMatch(dstPath);
 +                                expect(entry.name).toCanonicallyMatch(file1);
 +                                // test the moved file exists
 +                                directory.getFile(file1, {
 +                                    create : false
 +                                }, function (fileEntry) {
 +                                    expect(fileEntry).toBeDefined();
 +                                    expect(fileEntry.fullPath).toCanonicallyMatch(dstPath);
 +                                    root.getFile(file1, {
 +                                        create : false
 +                                    }, succeed.bind(null, done, 'root.getFile - Unexpected success callback, it should not get invalid or moved file: ' + file1), function (error) {
 +                                        expect(error).toBeDefined();
 +                                        expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                                        // cleanup
 +                                        deleteEntry(file1);
 +                                        deleteEntry(dir);
 +                                        done();
 +                                    });
 +                                }, failed.bind(null, done, 'directory.getFile - Error getting file : ' + file1 + ' from: ' + dir));
 +                            }, failed.bind(null, done, 'entry.moveTo - Error moving file : ' + file1 + ' to: ' + dir + ' with the same name'));
 +                        }, failed.bind(null, done, 'root.getDirectory - Error creating directory : ' + dir));
 +                    }, failed.bind(null, done, 'createFile - Error creating file : ' + file1));
 +                }, failed.bind(null, done, 'deleteEntry - Error removing directory : ' + dir));
 +            });
 +            it("file.spec.67 moveTo: directory to same parent", function (done) {
 +                var file1 = "file1",
 +                srcDir = "entry.move.dsp.srcDir",
 +                dstDir = "entry.move.dsp.dstDir",
 +                srcPath = joinURL(root.fullPath, srcDir),
 +                dstPath = joinURL(root.fullPath, dstDir),
 +                filePath = joinURL(dstPath, file1);
 +                // ensure destination directory is cleaned up before it
 +                deleteEntry(dstDir, function () {
 +                    // create a new directory entry to kick off it
 +                    createDirectory(srcDir, function (directory) {
 +                        // create a file within directory
 +                        directory.getFile(file1, {
 +                            create : true
 +                        }, function () {
 +                            // move srcDir to dstDir
 +                            directory.moveTo(root, dstDir, function (directory) {
 +                                expect(directory).toBeDefined();
 +                                expect(directory.isFile).toBe(false);
 +                                expect(directory.isDirectory).toBe(true);
 +                                expect(directory.fullPath).toCanonicallyMatch(dstPath);
 +                                expect(directory.name).toCanonicallyMatch(dstDir);
 +                                // test that moved file exists in destination dir
 +                                directory.getFile(file1, {
 +                                    create : false
 +                                }, function (fileEntry) {
 +                                    expect(fileEntry).toBeDefined();
 +                                    expect(fileEntry.fullPath).toCanonicallyMatch(filePath);
 +                                    // check that the moved file no longer exists in original dir
 +                                    root.getFile(file1, {
 +                                        create : false
 +                                    }, succeed.bind(null, done, 'directory.getFile - Unexpected success callback, it should not get invalid or moved file: ' + file1), function (error) {
 +                                        expect(error).toBeDefined();
 +                                        expect(error).toBeFileError(FileError.NOT_FOUND_ERR);
 +                                        // cleanup
 +                                        deleteEntry(srcDir);
 +                                        deleteEntry(dstDir);
 +                                        done();
 +                                    });
 +                                }, failed.bind(null, done, 'directory.getFile - Error getting file : ' + file1 + ' from: ' + srcDir));
 +                            }, failed.bind(null, done, 'entry.moveTo - Error moving directory : ' + srcDir + ' to root as: ' + dstDir));
 +                        }, failed.bind(null, done, 'directory.getFile - Error creating file : ' + file1));
 +                    }, failed.bind(null, done, 'createDirectory - Error creating directory : ' + srcDir));
 +                }, failed.bind(null, done, 'deleteEntry - Error removing directory : ' + dstDir));
 +            });
 +            it("file.spec.68 moveTo: directory to same parent with same name", function (done) {
 +                var file1 = "file1",
 +                srcDir = "entry.move.dsp.srcDir",
 +                dstDir = "entry.move.dsp.srcDir-backup",
 +                srcPath = joinURL(root.fullPath, srcDir),
 +                dstPath = joinURL(root.fullPath, dstDir),
 +                filePath = joinURL(dstPath, file1);
 +                // ensure destination directory is cleaned up before it
 +                deleteEntry(dstDir, function () {
 +                    // create a new directory entry to ki

<TRUNCATED>

[2/6] git commit: Merging to work on top of test framework changes

Posted by pu...@apache.org.
Merging to work on top of test framework changes


Project: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/repo
Commit: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/commit/f4eb0a09
Tree: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/tree/f4eb0a09
Diff: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/diff/f4eb0a09

Branch: refs/heads/master
Commit: f4eb0a09612610492e10c0b7a459f0d65714cfed
Parents: 2866283 83041f4
Author: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Authored: Wed Jul 23 16:39:23 2014 -0400
Committer: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Committed: Wed Jul 23 16:39:23 2014 -0400

----------------------------------------------------------------------
 tests/tests.js | 107 ++++++++++++++++++++++++++++++++++++++++++++++++----
 1 file changed, 100 insertions(+), 7 deletions(-)
----------------------------------------------------------------------



[5/6] git commit: rebase from master

Posted by pu...@apache.org.
rebase from master


Project: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/repo
Commit: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/commit/76f33578
Tree: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/tree/76f33578
Diff: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/diff/76f33578

Branch: refs/heads/master
Commit: 76f33578b5132a39db0ee73ea765e5e248a17e97
Parents: 19f17a7 33797d5
Author: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Authored: Mon Aug 18 11:55:52 2014 -0400
Committer: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Committed: Mon Aug 18 11:55:52 2014 -0400

----------------------------------------------------------------------
 README.md                        |   2 +-
 RELEASENOTES.md                  |  42 +-
 doc/de/index.md                  | 158 ++++--
 doc/es/index.md                  | 158 ++++--
 doc/fr/index.md                  | 158 ++++--
 doc/index.md                     |   7 +-
 doc/it/index.md                  | 158 ++++--
 doc/ja/index.md                  | 158 ++++--
 doc/ko/index.md                  | 158 ++++--
 doc/pl/index.md                  | 182 +++++--
 doc/ru/index.md                  | 158 ++++--
 doc/zh/index.md                  | 168 ++++--
 plugin.xml                       |  26 +-
 src/firefoxos/FileProxy.js       | 205 ++++++--
 src/windows/FileProxy.js         | 943 ++++++++++++++++++++++++++++++++++
 src/windows8/FileProxy.js        | 250 ++++-----
 tests/plugin.xml                 |   1 +
 www/DirectoryEntry.js            |   2 +-
 www/Entry.js                     |   9 +-
 www/firefoxos/FileSystem.js      |  29 ++
 www/resolveLocalFileSystemURI.js |   7 +-
 21 files changed, 2332 insertions(+), 647 deletions(-)
----------------------------------------------------------------------



[4/6] git commit: added documentation for manual tests

Posted by pu...@apache.org.
added documentation for manual tests


Project: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/repo
Commit: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/commit/19f17a71
Tree: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/tree/19f17a71
Diff: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/diff/19f17a71

Branch: refs/heads/master
Commit: 19f17a71e14105aa1b19edba491613afde305f13
Parents: 8ff7d17
Author: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Authored: Thu Jul 24 16:42:13 2014 -0400
Committer: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Committed: Thu Jul 24 16:42:13 2014 -0400

----------------------------------------------------------------------
 tests/tests.js | 19 +++++++++++++++++++
 1 file changed, 19 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/blob/19f17a71/tests/tests.js
----------------------------------------------------------------------
diff --git a/tests/tests.js b/tests/tests.js
index 0d6edc8..8c0b97a 100644
--- a/tests/tests.js
+++ b/tests/tests.js
@@ -3123,6 +3123,11 @@ exports.defineManualTests = function (contentEl, createActionButton) {
     div.appendChild(document.createTextNode('File Systems'));
     div.setAttribute("align", "center");
     contentEl.appendChild(div);
+
+    div = document.createElement('h3');
+    div.appendChild(document.createTextNode('Results are displayed in yellow status box below with expected results noted under that'));
+    div.setAttribute("align", "center");
+    contentEl.appendChild(div);
     
     div = document.createElement('div');
     div.setAttribute("id", "button");
@@ -3149,4 +3154,18 @@ exports.defineManualTests = function (contentEl, createActionButton) {
     div.setAttribute("id", "info");
     div.setAttribute("align", "center");
     contentEl.appendChild(div);
+
+    div = document.createElement('h3');
+    div.appendChild(document.createTextNode('For each test above, file or directory should be successfully found. ' +
+        'Status box should say Resolving URL was Success. The first URL resolved is the internal URL. ' +
+        'The second URL resolved is the absolute URL. Blue URLs must match.'));
+    div.setAttribute("align", "center");
+    contentEl.appendChild(div);
+
+    div = document.createElement('h3');
+    div.appendChild(document.createTextNode('For Test private URL (iOS), the private URL (first blue URL in status box) ' +
+        'should be successfully resolved. Status box should say Successfully resolved. Both blue URLs below ' +
+        'that should match.'));
+    div.setAttribute("align", "center");
+    contentEl.appendChild(div);
 };


[3/6] git commit: Merging to work on top of relative paths change

Posted by pu...@apache.org.
Merging to work on top of relative paths change


Project: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/repo
Commit: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/commit/8ff7d173
Tree: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/tree/8ff7d173
Diff: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/diff/8ff7d173

Branch: refs/heads/master
Commit: 8ff7d173948beefb7864aed60170d6fe2c0d0ee0
Parents: f4eb0a0 4152181
Author: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Authored: Wed Jul 23 16:39:59 2014 -0400
Committer: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Committed: Wed Jul 23 16:39:59 2014 -0400

----------------------------------------------------------------------
 src/wp/File.cs | 33 +++++++++++++++++++++++++++++++--
 1 file changed, 31 insertions(+), 2 deletions(-)
----------------------------------------------------------------------



[6/6] git commit: cb-6724changed style detail on documentation

Posted by pu...@apache.org.
cb-6724changed style detail on documentation


Project: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/repo
Commit: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/commit/3086907f
Tree: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/tree/3086907f
Diff: http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/diff/3086907f

Branch: refs/heads/master
Commit: 3086907f8a99c38b3336ce6805bc9fe2ef61969b
Parents: 76f3357
Author: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Authored: Mon Aug 18 13:38:29 2014 -0400
Committer: Edna Morales <ed...@ednas-mbp-2.raleigh.ibm.com>
Committed: Mon Aug 18 13:38:29 2014 -0400

----------------------------------------------------------------------
 tests/tests.js | 2 --
 1 file changed, 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/cordova-plugin-file/blob/3086907f/tests/tests.js
----------------------------------------------------------------------
diff --git a/tests/tests.js b/tests/tests.js
index 8c0b97a..f908f0c 100644
--- a/tests/tests.js
+++ b/tests/tests.js
@@ -3159,13 +3159,11 @@ exports.defineManualTests = function (contentEl, createActionButton) {
     div.appendChild(document.createTextNode('For each test above, file or directory should be successfully found. ' +
         'Status box should say Resolving URL was Success. The first URL resolved is the internal URL. ' +
         'The second URL resolved is the absolute URL. Blue URLs must match.'));
-    div.setAttribute("align", "center");
     contentEl.appendChild(div);
 
     div = document.createElement('h3');
     div.appendChild(document.createTextNode('For Test private URL (iOS), the private URL (first blue URL in status box) ' +
         'should be successfully resolved. Status box should say Successfully resolved. Both blue URLs below ' +
         'that should match.'));
-    div.setAttribute("align", "center");
     contentEl.appendChild(div);
 };