You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@flex.apache.org by ah...@apache.org on 2012/10/19 02:08:13 UTC

svn commit: r1399933 - in /incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser: ./ src/ src/MustellaTestChooser-app.xml src/MustellaTestChooser.mxml

Author: aharui
Date: Fri Oct 19 00:08:13 2012
New Revision: 1399933

URL: http://svn.apache.org/viewvc?rev=1399933&view=rev
Log:
Test Selection Utility.  Uses deps.xml file generated by MustellaDependencyDB.  Copy and paste SVN status (use svn status | grep '^M' to just get changed files) and it will create a changes.txt file.  Use mini_run.sh -changes to run all of those tests.

Added:
    incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/
    incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/
    incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml   (with props)
    incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml   (with props)

Added: incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml
URL: http://svn.apache.org/viewvc/incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml?rev=1399933&view=auto
==============================================================================
--- incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml (added)
+++ incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml Fri Oct 19 00:08:13 2012
@@ -0,0 +1,250 @@
+<?xml version="1.0" encoding="utf-8" standalone="no"?>
+<!--
+
+  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.
+
+-->
+<application xmlns="http://ns.adobe.com/air/application/3.1">
+
+<!-- Adobe AIR Application Descriptor File Template.
+
+	Specifies parameters for identifying, installing, and launching AIR applications.
+
+	xmlns - The Adobe AIR namespace: http://ns.adobe.com/air/application/3.1
+			The last segment of the namespace specifies the version 
+			of the AIR runtime required for this application to run.
+			
+	minimumPatchLevel - The minimum patch level of the AIR runtime required to run 
+			the application. Optional.
+-->
+
+	<!-- A universally unique application identifier. Must be unique across all AIR applications.
+	Using a reverse DNS-style name as the id is recommended. (Eg. com.example.ExampleApplication.) Required. -->
+	<id>MustellaTestChooser</id>
+
+	<!-- Used as the filename for the application. Required. -->
+	<filename>MustellaTestChooser</filename>
+
+	<!-- The name that is displayed in the AIR application installer. 
+	May have multiple values for each language. See samples or xsd schema file. Optional. -->
+	<name>MustellaTestChooser</name>
+	
+	<!-- A string value of the format <0-999>.<0-999>.<0-999> that represents application version which can be used to check for application upgrade. 
+	Values can also be 1-part or 2-part. It is not necessary to have a 3-part value.
+	An updated version of application must have a versionNumber value higher than the previous version. Required for namespace >= 2.5 . -->
+	<versionNumber>0.0.0</versionNumber>
+		         
+	<!-- A string value (such as "v1", "2.5", or "Alpha 1") that represents the version of the application, as it should be shown to users. Optional. -->
+	<!-- <versionLabel></versionLabel> -->
+
+	<!-- Description, displayed in the AIR application installer.
+	May have multiple values for each language. See samples or xsd schema file. Optional. -->
+	<!-- <description></description> -->
+
+	<!-- Copyright information. Optional -->
+	<!-- <copyright></copyright> -->
+
+	<!-- Publisher ID. Used if you're updating an application created prior to 1.5.3 -->
+	<!-- <publisherID></publisherID> -->
+
+	<!-- Settings for the application's initial window. Required. -->
+	<initialWindow>
+		<!-- The main SWF or HTML file of the application. Required. -->
+		<!-- Note: In Flash Builder, the SWF reference is set automatically. -->
+		<content>[This value will be overwritten by Flash Builder in the output app.xml]</content>
+		
+		<!-- The title of the main window. Optional. -->
+		<!-- <title></title> -->
+
+		<!-- The type of system chrome to use (either "standard" or "none"). Optional. Default standard. -->
+		<!-- <systemChrome></systemChrome> -->
+
+		<!-- Whether the window is transparent. Only applicable when systemChrome is none. Optional. Default false. -->
+		<!-- <transparent></transparent> -->
+
+		<!-- Whether the window is initially visible. Optional. Default false. -->
+		<!-- <visible></visible> -->
+
+		<!-- Whether the user can minimize the window. Optional. Default true. -->
+		<!-- <minimizable></minimizable> -->
+
+		<!-- Whether the user can maximize the window. Optional. Default true. -->
+		<!-- <maximizable></maximizable> -->
+
+		<!-- Whether the user can resize the window. Optional. Default true. -->
+		<!-- <resizable></resizable> -->
+
+		<!-- The window's initial width in pixels. Optional. -->
+		<!-- <width></width> -->
+
+		<!-- The window's initial height in pixels. Optional. -->
+		<!-- <height></height> -->
+
+		<!-- The window's initial x position. Optional. -->
+		<!-- <x></x> -->
+
+		<!-- The window's initial y position. Optional. -->
+		<!-- <y></y> -->
+
+		<!-- The window's minimum size, specified as a width/height pair in pixels, such as "400 200". Optional. -->
+		<!-- <minSize></minSize> -->
+
+		<!-- The window's initial maximum size, specified as a width/height pair in pixels, such as "1600 1200". Optional. -->
+		<!-- <maxSize></maxSize> -->
+
+        <!-- The initial aspect ratio of the app when launched (either "portrait" or "landscape"). Optional. Mobile only. Default is the natural orientation of the device -->
+
+        <!-- <aspectRatio></aspectRatio> -->
+
+        <!-- Whether the app will begin auto-orienting on launch. Optional. Mobile only. Default false -->
+
+        <!-- <autoOrients></autoOrients> -->
+
+        <!-- Whether the app launches in full screen. Optional. Mobile only. Default false -->
+
+        <!-- <fullScreen></fullScreen> -->
+
+        <!-- The render mode for the app (either auto, cpu, gpu, or direct). Optional. Default auto -->
+
+        <!-- <renderMode></renderMode> -->
+
+		<!-- Whether or not to pan when a soft keyboard is raised or lowered (either "pan" or "none").  Optional.  Defaults "pan." -->
+		<!-- <softKeyboardBehavior></softKeyboardBehavior> -->
+	<autoOrients>false</autoOrients>
+        <fullScreen>false</fullScreen>
+        <visible>false</visible>
+    </initialWindow>
+
+	<!-- We recommend omitting the supportedProfiles element, -->
+	<!-- which in turn permits your application to be deployed to all -->
+	<!-- devices supported by AIR. If you wish to restrict deployment -->
+	<!-- (i.e., to only mobile devices) then add this element and list -->
+	<!-- only the profiles which your application does support. -->
+	<!-- <supportedProfiles>desktop extendedDesktop mobileDevice extendedMobileDevice</supportedProfiles> -->
+
+	<!-- The subpath of the standard default installation location to use. Optional. -->
+	<!-- <installFolder></installFolder> -->
+
+	<!-- The subpath of the Programs menu to use. (Ignored on operating systems without a Programs menu.) Optional. -->
+	<!-- <programMenuFolder></programMenuFolder> -->
+
+	<!-- The icon the system uses for the application. For at least one resolution,
+	specify the path to a PNG file included in the AIR package. Optional. -->
+	<!-- <icon>
+		<image16x16></image16x16>
+		<image32x32></image32x32>
+		<image36x36></image36x36>
+		<image48x48></image48x48>
+		<image57x57></image57x57>
+		<image72x72></image72x72>
+		<image114x114></image114x114>
+		<image128x128></image128x128>
+	</icon> -->
+
+	<!-- Whether the application handles the update when a user double-clicks an update version
+	of the AIR file (true), or the default AIR application installer handles the update (false).
+	Optional. Default false. -->
+	<!-- <customUpdateUI></customUpdateUI> -->
+	
+	<!-- Whether the application can be launched when the user clicks a link in a web browser.
+	Optional. Default false. -->
+	<!-- <allowBrowserInvocation></allowBrowserInvocation> -->
+
+	<!-- Listing of file types for which the application can register. Optional. -->
+	<!-- <fileTypes> -->
+
+		<!-- Defines one file type. Optional. -->
+		<!-- <fileType> -->
+
+			<!-- The name that the system displays for the registered file type. Required. -->
+			<!-- <name></name> -->
+
+			<!-- The extension to register. Required. -->
+			<!-- <extension></extension> -->
+			
+			<!-- The description of the file type. Optional. -->
+			<!-- <description></description> -->
+			
+			<!-- The MIME content type. -->
+			<!-- <contentType></contentType> -->
+			
+			<!-- The icon to display for the file type. Optional. -->
+			<!-- <icon>
+				<image16x16></image16x16>
+				<image32x32></image32x32>
+				<image48x48></image48x48>
+				<image128x128></image128x128>
+			</icon> -->
+			
+		<!-- </fileType> -->
+	<!-- </fileTypes> -->
+
+    <!-- iOS specific capabilities -->
+	<!-- <iPhone> -->
+		<!-- A list of plist key/value pairs to be added to the application Info.plist -->
+		<!-- <InfoAdditions>
+            <![CDATA[
+                <key>UIDeviceFamily</key>
+                <array>
+                    <string>1</string>
+                    <string>2</string>
+                </array>
+                <key>UIStatusBarStyle</key>
+                <string>UIStatusBarStyleBlackOpaque</string>
+                <key>UIRequiresPersistentWiFi</key>
+                <string>YES</string>
+            ]]>
+        </InfoAdditions> -->
+        <!-- A list of plist key/value pairs to be added to the application Entitlements.plist -->
+		<!-- <Entitlements>
+            <![CDATA[
+                <key>keychain-access-groups</key>
+                <array>
+                    <string></string>
+                    <string></string>
+                </array>
+            ]]>
+        </Entitlements> -->
+	<!-- Display Resolution for the app (either "standard" or "high"). Optional. Default "standard" -->
+	<!-- <requestedDisplayResolution></requestedDisplayResolution> -->
+	<!-- </iPhone> -->
+
+	<!-- Specify Android specific tags that get passed to AndroidManifest.xml file. -->
+    <!--<android> -->
+    <!--	<manifestAdditions>
+		<![CDATA[
+			<manifest android:installLocation="auto">
+				<uses-permission android:name="android.permission.INTERNET"/>
+				<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
+				<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
+				<uses-feature android:required="true" android:name="android.hardware.touchscreen.multitouch"/>
+				<application android:enabled="true">
+					<activity android:excludeFromRecents="false">
+						<intent-filter>
+							<action android:name="android.intent.action.MAIN"/>
+							<category android:name="android.intent.category.LAUNCHER"/>
+						</intent-filter>
+					</activity>
+				</application>
+            </manifest>
+		]]>
+        </manifestAdditions> -->
+	    <!-- Color depth for the app (either "32bit" or "16bit"). Optional. Default 16bit before namespace 3.0, 32bit after -->
+        <!-- <colorDepth></colorDepth> -->
+    <!-- </android> -->
+	<!-- End of the schema for adding the android specific tags in AndroidManifest.xml file -->
+
+</application>

Propchange: incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser-app.xml
------------------------------------------------------------------------------
    svn:eol-style = native

Added: incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml
URL: http://svn.apache.org/viewvc/incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml?rev=1399933&view=auto
==============================================================================
--- incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml (added)
+++ incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml Fri Oct 19 00:08:13 2012
@@ -0,0 +1,241 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!--
+
+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.
+
+-->
+<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" 
+					   xmlns:s="library://ns.adobe.com/flex/spark" 
+					   xmlns:mx="library://ns.adobe.com/flex/mx">
+	<fx:Declarations>
+		<!-- Place non-visual elements (e.g., services, value objects) here -->
+	</fx:Declarations>
+	<fx:Script>
+		<![CDATA[
+			private var dirFile:File = new File();
+			private var fs:FileStream;
+
+			private function browse():void
+			{
+				dirFile.addEventListener(Event.SELECT, selectHandler);
+				dirFile.browseForDirectory("Mustella Directory");
+			}
+			
+			private function selectHandler(event:Event):void
+			{
+				dir.text = dirFile.nativePath;	
+			}
+			
+			private function computeTests():void
+			{
+				dirFile.nativePath = dir.text;
+				
+				var files:Array = statusLog.text.split("\n");
+				var modFiles:Array = [];
+				var n:int = files.length;
+				for (var i:int = 0; i < n; i++)
+				{
+					var file:String = files[i];
+					if (file.charAt(0) == "M")
+					{
+						modFiles.push(file);
+					}
+				}
+				
+				readDB();
+				
+				findTests();
+				
+				// flattenTests();
+				computeTestDependencies();
+				
+				n = modFiles.length;
+				for (i = 0; i < n; i++)
+				{
+					file = modFiles[i];
+					file = file.substr(8);
+					var c:int;
+					c = file.indexOf(".as");
+					if (c != -1)
+						file = file.substr(0, c);
+					else
+					{
+						c = file.indexOf(".mxml");
+						if (c != -1)
+							file = file.substr(0, c);
+					}
+					c = file.indexOf("/src/");
+					if (c != -1)
+						file = file.substr(c + 5);
+					c = file.lastIndexOf("/");
+					if (c != -1)
+						file = file.substring(0, c) + ':' + file.substr(c + 1);
+					file = file.replace(/\//g, ".");
+					modFiles[i] = file;
+				}
+				var runTests:Array = [];
+				var m:int = testNames.length;				
+				for (i = 0; i < n; i++)
+				{
+					for (var j:int = 0; j < m; j++)
+					{
+						if (testDeps[testNames[j]][modFiles[i]])
+							runTests.push(testNames[j]);
+					}
+				}
+				runTests.sort();
+				var s:String = "";
+				n = runTests.length;
+				for (i = 0; i < n; i++)
+				{
+					//trace(runTests[i]);
+					s += runTests[i].substr(7) + "\n"; // clip leading '/tests/'
+				}
+				output.text = s;
+				doneLabel.visible = true;
+				var f:File = new File(dirFile.nativePath + "/" + "changes.txt");
+				try
+				{
+					var fs:FileStream = new FileStream();
+					fs.open(f, FileMode.WRITE);
+					fs.writeUTFBytes(s);
+					fs.close();
+				}
+				catch (e:Error)
+				{
+					
+				}
+			}
+			
+			private var db:Object = {};
+			
+			private function readDB():void
+			{
+				var f:File = new File(dirFile.nativePath + "/" + "deps.xml");
+				try
+				{
+					var fs:FileStream = new FileStream();
+					fs.open(f, FileMode.READ);
+					var s:String = fs.readUTFBytes(fs.bytesAvailable);
+					var xml:XML = XML(s);
+					var scripts:XMLList = xml.script;
+					var n:int = scripts.length();
+					for (var i:int = 0; i < n; i++)
+					{
+						var script:XML = scripts[i];
+						var deps:XMLList = script.dep;
+						var m:int= deps.length();
+						var deplst:Object = {};
+						for (var j:int = 0; j < m; j++)
+						{
+							deplst[deps[j].@name] = 1;
+						}
+						db[script.@name] = deplst;
+					}
+					fs.close();
+				}
+				catch (e:Error)
+				{
+					
+				}
+			}
+
+			private var testNames:Array = [];
+			
+			private function findTests():void
+			{
+				// tests extend UnitTester
+				for (var p:String in db)
+				{
+					if (db[p]["UnitTester"] == 1)
+					{
+						// make sure it isn't a test step
+						if (p.indexOf("as3/src/") == -1) 
+							testNames.push(p);
+					}
+				}
+			}
+			
+			private var testDeps:Object = {};
+			
+			private function computeTestDependencies():void
+			{
+				for each (var p:String in testNames)
+				{
+					testDeps[p] = {};
+					addDeps(p, [testDeps[p]]);
+				}
+				
+			}
+			
+			private var inProgress:Object = {};
+			
+			private function addDeps(p:String, arr:Array):void
+			{
+				//trace(p);
+				
+				for each (var o:Object in arr)
+				{
+					o[p] = 1;
+				}
+				var deps:Object = db[p];
+				for (var q:String in deps)
+				{
+					o = testDeps[q];
+					if (o == null)
+					{
+						if (inProgress[q] == null)
+						{
+							o = {};
+							inProgress[q] = o;
+							arr.push(o);
+							addDeps(q, arr);
+							arr.pop();
+							testDeps[q] = o;
+							delete inProgress[q];
+						}
+					}
+					else
+					{
+						for (var r:String in o)
+						{
+							for each (var s:Object in arr)
+							{
+								s[r] = 1;
+							}
+						}
+					}
+					
+				}
+			}
+		]]>
+	</fx:Script>
+	<s:layout>
+		<s:VerticalLayout />
+	</s:layout>
+	<s:HGroup width="100%">
+		<s:Label text="Mustella Directory:" />
+		<s:TextInput id="dir" width="100%" toolTip="The mustella dir, not the tests dir"/>
+		<s:Button label="Browse..." click="browse()" />
+	</s:HGroup>
+	<s:Label text="Copy and paste SVN Status below" />
+	<s:TextArea id="statusLog" width="100%" change="doneLabel.visible=false"/>
+	<s:HGroup>
+		<s:Button label="Compute Tests" enabled="{statusLog.text.length > 0}" click="callLater(computeTests)" />
+		<s:Label id="doneLabel" visible="false" text="Wrote changes.txt. Use mini_run.sh -changes" />
+	</s:HGroup>
+	<s:TextArea id="output" width="100%" editable="false" lineBreak="explicit" horizontalScrollPolicy="auto" />
+</s:WindowedApplication>

Propchange: incubator/flex/sdk/branches/develop/mustella/utilities/MustellaTestChooser/src/MustellaTestChooser.mxml
------------------------------------------------------------------------------
    svn:eol-style = native