FileDocCategorySizeDatePackage
FileDescriptorTest.javaAPI DocAndroid 1.5 API4622Wed May 06 22:41:04 BST 2009tests.api.java.io

FileDescriptorTest.java

/*
 *  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.
 */

package tests.api.java.io;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileDescriptor;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.RandomAccessFile;

import dalvik.annotation.TestLevel;
import dalvik.annotation.TestTargetClass;
import dalvik.annotation.TestTargetNew;

@TestTargetClass(FileDescriptor.class) 
public class FileDescriptorTest extends junit.framework.TestCase {

    private static String platformId = "JDK"
            + System.getProperty("java.vm.version").replace('.', '-');

    FileOutputStream fos;

    BufferedOutputStream os;

    FileInputStream fis;

    File f;

    /**
     * @tests java.io.FileDescriptor#FileDescriptor()
     */
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        method = "FileDescriptor",
        args = {}
    )     
    public void test_Constructor() {
        // Test for method java.io.FileDescriptor()
        FileDescriptor fd = new FileDescriptor();
        assertTrue("Failed to create FileDescriptor",
                fd instanceof FileDescriptor);
    }

    /**
     * @tests java.io.FileDescriptor#sync()
     */
    @TestTargetNew(
        level = TestLevel.SUFFICIENT,
        notes = "SyncFailedException not checked since it is only thrown" +
                "by the native implementation of sync().",
        method = "sync",
        args = {}
    )    
       public void test_sync() throws Exception {
        // Test for method void java.io.FileDescriptor.sync()
        f = File.createTempFile("fd" + platformId, ".tst");
        f.delete();
        fos = new FileOutputStream(f.getPath());
        fos.write("Test String".getBytes());
        fis = new FileInputStream(f.getPath());
        FileDescriptor fd = fos.getFD();
        fd.sync();
        int length = "Test String".length();
        assertEquals("Bytes were not written after sync", length, fis
                .available());
        
        // Regression test for Harmony-1494
        fd = fis.getFD();
        fd.sync();
        assertEquals("Bytes were not written after sync", length, fis
                .available());
        
        RandomAccessFile raf = new RandomAccessFile(f, "r");
        fd = raf.getFD(); 
        fd.sync();
        raf.close();
    }

    /**
     * @tests java.io.FileDescriptor#valid()
     */
    @TestTargetNew(
        level = TestLevel.COMPLETE,
        method = "valid",
        args = {}
    )        
    public void test_valid() {
        // Test for method boolean java.io.FileDescriptor.valid()
        try {
            f = new File(System.getProperty("java.io.tmpdir"), "fd.tst");
            f.delete();
            os = new BufferedOutputStream(fos = new FileOutputStream(f
                    .getPath()), 4096);
            FileDescriptor fd = fos.getFD();
            assertTrue("Valid fd returned false", fd.valid());
            os.close();
            assertTrue("Invalid fd returned true", !fd.valid());
        } catch (Exception e) {
            fail("Exception during test : " + e.getMessage());
        }

    }

    /**
     * Sets up the fixture, for example, open a network connection. This method
     * is called before a test is executed.
     */
    protected void setUp() {
    }

    /**
     * Tears down the fixture, for example, close a network connection. This
     * method is called after a test is executed.
     */
    protected void tearDown() {
        try {
            os.close();
        } catch (Exception e) {
        }
        try {
            fis.close();
        } catch (Exception e) {
        }
        try {
            fos.close();
        } catch (Exception e) {
        }
        try {
            f.delete();
        } catch (Exception e) {
        }
    }

    protected void doneSuite() {
    }
}