Back to index

lightning-sunbird  0.9+nobinonly
CreateThread.cpp
Go to the documentation of this file.
00001 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
00002  * ***** BEGIN LICENSE BLOCK *****
00003  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
00004  *
00005  * The contents of this file are subject to the Mozilla Public License Version
00006  * 1.1 (the "License"); you may not use this file except in compliance with
00007  * the License. You may obtain a copy of the License at
00008  * http://www.mozilla.org/MPL/
00009  *
00010  * Software distributed under the License is distributed on an "AS IS" basis,
00011  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
00012  * for the specific language governing rights and limitations under the
00013  * License.
00014  *
00015  * The Original Code is mozilla.org code.
00016  *
00017  * The Initial Developer of the Original Code is
00018  * Sun Microsystems, Inc.
00019  * Portions created by the Initial Developer are Copyright (C) 1999
00020  * the Initial Developer. All Rights Reserved.
00021  *
00022  * Contributor(s):
00023  *
00024  * Alternatively, the contents of this file may be used under the terms of
00025  * either the GNU General Public License Version 2 or later (the "GPL"), or
00026  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
00027  * in which case the provisions of the GPL or the LGPL are applicable instead
00028  * of those above. If you wish to allow use of your version of this file only
00029  * under the terms of either the GPL or the LGPL, and not to allow others to
00030  * use your version of this file under the terms of the MPL, indicate your
00031  * decision by deleting the provisions above and replace them with the notice
00032  * and other provisions required by the GPL or the LGPL. If you do not delete
00033  * the provisions above, a recipient may use your version of this file under
00034  * the terms of any one of the MPL, the GPL or the LGPL.
00035  *
00036  * ***** END LICENSE BLOCK ***** */
00037 #include <ThreadManagerTests.h>
00038 //CreateThread
00039 
00040 TM_OJIAPITest(ThreadManager_CreateThread_1) {
00041        GET_TM_FOR_TEST
00042        nsresult rc = threadMgr->CreateThread(NULL, NULL);
00043        if (NS_FAILED(rc))
00044               return TestResult::PASS("Method should fail because no nsIRunnable object is specified.");
00045        return TestResult::FAIL("CreateThread", rc);
00046 
00047 }
00048 
00049 TM_OJIAPITest(ThreadManager_CreateThread_2) {
00050        GET_TM_FOR_TEST
00051        PRUint32 id;
00052 
00053        nsresult rc = threadMgr->CreateThread(&id, NULL);
00054        if (NS_FAILED(rc))
00055               return TestResult::PASS("Method should fail because no nsIRunnable object is specified.");
00056        return TestResult::FAIL("CreateThread", rc);
00057 
00058 }
00059 
00060 TM_OJIAPITest(ThreadManager_CreateThread_3) {
00061        GET_TM_FOR_TEST
00062        class DummyThread : public BaseDummyThread {
00063        public:
00064               DummyThread() {}
00065               NS_METHOD Run() { while(1); return NS_OK; }
00066        };
00067 
00068        DummyThread *dt = new DummyThread();
00069        nsresult rc = threadMgr->CreateThread(NULL, (nsIRunnable*)dt);
00070        if (NS_FAILED(rc))
00071               return TestResult::PASS("Method should fail because no space is allocated for thread id.");
00072        return TestResult::FAIL("CreateThread", rc);
00073        
00074 }
00075 
00076 TM_OJIAPITest(ThreadManager_CreateThread_4) {
00077        GET_TM_FOR_TEST
00078        class DummyThread : public BaseDummyThread {
00079        public:
00080               DummyThread() {}
00081               NS_METHOD Run() { while(1); return NS_OK; }
00082        };
00083        PRUint32 id = 0;
00084        DummyThread *dt = new DummyThread();
00085        nsresult rc = threadMgr->CreateThread(&id, (nsIRunnable*)dt);  
00086        if (NS_SUCCEEDED(rc))
00087               return TestResult::PASS("Method should work OK.");
00088        return TestResult::FAIL("");
00089 
00090 }