|
From: <luk...@us...> - 2006-09-05 04:19:31
|
Revision: 71
http://svn.sourceforge.net/asunit/?rev=71&view=rev
Author: lukebayes
Date: 2006-09-04 21:19:18 -0700 (Mon, 04 Sep 2006)
Log Message:
-----------
working on ruby tools
Modified Paths:
--------------
trunk/ruby/src/asunit.rb
Added Paths:
-----------
trunk/ruby/demo/
trunk/ruby/src/createclass.rb
trunk/ruby/src/createclass_test.rb
trunk/ruby/src/project.rb
trunk/ruby/src/project_test.rb
trunk/ruby/src/settings.rb
trunk/ruby/src/settings_test.rb
trunk/ruby/test/
Modified: trunk/ruby/src/asunit.rb
===================================================================
--- trunk/ruby/src/asunit.rb 2006-09-02 06:12:17 UTC (rev 70)
+++ trunk/ruby/src/asunit.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -1,4 +1,4 @@
-#!/usr/bin/env ruby
+#!/bin/ruby
module AsUnit
# ------------------------------------------------------------------
@@ -39,17 +39,50 @@
end
end
- class Application
- def initialize
+ require 'optparse'
+
+ class Application
+ def initialize
+ super
+ arguments = AsUnitArguments.new(ARGV)
+ counter = 0
+ eol =
+ ARGF.each do |line|
+ line.sub!(/$/, arguments[:show_ends])
+ print '%6.d ' % (counter += 1) if arguments[:number_lines]
+ print line
+ end
+ end
+ end
+
+ class AsUnitArguments < Hash
+ def initialize(args)
super
+ self[:show_ends] = ''
+ self[:number_lines] = false
+
+ opts = OptionParser.new do |opts|
+ opts.banner = "Usage: #$0 [options]"
+ opts.on('-E', '--show-ends [STRING]',
+ 'display [STRING] at end of each line') do |string|
+ self[:show_ends] = string || '$'
+ end
+
+ opts.on('-n', '--number', 'number all output lines') do
+ self[:number_lines] = true
+ end
+
+ opts.on_tail('-h', '--help', 'display this help and exit') do
+ puts opts
+ exit
+ end
+ opts.parse!(args)
+
+ end
end
-
- def run
- printf "Hello Nancy"
- end
end
end
if __FILE__ == $0 then
- AsUnit::Application.new.run
+ AsUnit::Application.new
end
Added: trunk/ruby/src/createclass.rb
===================================================================
--- trunk/ruby/src/createclass.rb (rev 0)
+++ trunk/ruby/src/createclass.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,12 @@
+
+module AsUnit
+ class CreateClass
+ def initialize name
+ @classname = name;
+ end
+
+ def full_class_name
+ return @classname
+ end
+ end
+end
Added: trunk/ruby/src/createclass_test.rb
===================================================================
--- trunk/ruby/src/createclass_test.rb (rev 0)
+++ trunk/ruby/src/createclass_test.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,20 @@
+
+require 'test/unit'
+require 'createclass.rb'
+
+class CreateClassTest < Test::Unit::TestCase
+
+ def setup
+ @full_class_name = "org.asunit.SomeClass"
+ @instance = AsUnit::CreateClass.new @full_class_name
+ end
+
+ def test_instantiated
+ assert_not_nil(@instance)
+ end
+
+ def test_class_name
+ assert(@instance.full_class_name == @full_class_name)
+ end
+
+end
\ No newline at end of file
Added: trunk/ruby/src/project.rb
===================================================================
--- trunk/ruby/src/project.rb (rev 0)
+++ trunk/ruby/src/project.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,67 @@
+#!/bin/ruby
+
+require 'settings.rb'
+
+module AsUnit
+ #################################
+ # Project Class
+ #################################
+ # Should be able to enter something like:
+ # asunit project Lifebin
+ # and get an auto-configured ready-to-go
+ # actionscript project file, folders etc...
+ # -src [source dir name]
+ # -test [test dir name]
+ # -path [colon-separated, space-escaped directory paths]
+ # -lib [lib dir name]
+ # -bin [binary dir name]
+
+ class Project
+ attr_reader :name, :settings
+
+ def initialize(name, dir=nil)
+ @name = name;
+ @settings = AsUnit::Settings.new
+ if(!dir.nil?)
+ @dir = dir
+ end
+ content = create_dirs
+ create_project_file('.asunit_' + name.downcase, content)
+ end
+
+ def create_dirs
+ create_dir(@settings.src)
+ create_dir(@settings.test)
+ create_dir(@settings.lib)
+
+ contents = ['src=\'' + File.expand_path(@settings.src) + '\'']
+ contents.push('test=\'' + File.expand_path(@settings.test) + '\'')
+ contents.push('lib=\'' + File.expand_path(@settings.lib) + '\'')
+ end
+
+ def create_project_file(name, contents)
+ open(name, 'w') do |f|
+ contents.each { |i|
+ f.puts i
+ }
+ f.flush
+ end
+ end
+
+ def dir
+ if(@dir.nil?)
+ @dir = Dir.pwd
+ end
+ @dir
+ end
+
+ def create_dir(name)
+ # Don't overwrite existing dirs
+ if(!File.exists? name)
+ Dir.mkdir name
+ end
+ return File.new name
+ end
+
+ end
+end
\ No newline at end of file
Added: trunk/ruby/src/project_test.rb
===================================================================
--- trunk/ruby/src/project_test.rb (rev 0)
+++ trunk/ruby/src/project_test.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,21 @@
+#!/bin/ruby
+
+require 'test/unit'
+require 'project.rb'
+require 'settings.rb'
+
+class ProjectTest < Test::Unit::TestCase
+
+ def setup
+ @default_name = 'Lifebin'
+ @instance = AsUnit::Project.new @default_name
+ end
+
+ def test_instantiated
+ assert_not_nil(@instance)
+ end
+
+ def test_name
+ assert_equal(@instance.name, @default_name)
+ end
+end
Added: trunk/ruby/src/settings.rb
===================================================================
--- trunk/ruby/src/settings.rb (rev 0)
+++ trunk/ruby/src/settings.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,12 @@
+
+module AsUnit
+ class Settings
+ attr_accessor :src, :test, :lib
+
+ def initialize()
+ @src = 'src'
+ @test = 'test'
+ @lib = 'lib'
+ end
+ end
+end
\ No newline at end of file
Added: trunk/ruby/src/settings_test.rb
===================================================================
--- trunk/ruby/src/settings_test.rb (rev 0)
+++ trunk/ruby/src/settings_test.rb 2006-09-05 04:19:18 UTC (rev 71)
@@ -0,0 +1,14 @@
+
+require 'test/unit'
+require 'settings.rb'
+
+class SettingsTest < Test::Unit::TestCase
+
+ def setup
+ @instance = AsUnit::Settings.new
+ end
+
+ def test_instantiated
+ assert_not_nil(@instance)
+ end
+end
\ No newline at end of file
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
|
|
From: <luk...@us...> - 2006-09-05 14:56:37
|
Revision: 74
http://svn.sourceforge.net/asunit/?rev=74&view=rev
Author: lukebayes
Date: 2006-09-05 07:56:29 -0700 (Tue, 05 Sep 2006)
Log Message:
-----------
added templates to repository
Added Paths:
-----------
trunk/ruby/templates/
trunk/ruby/templates/Class.erb
trunk/ruby/templates/TestCase.erb
trunk/ruby/templates/TestRunner.erb
trunk/ruby/templates/TestSuite.erb
trunk/ruby/templates/VisualTestCase.erb
Added: trunk/ruby/templates/Class.erb
===================================================================
--- trunk/ruby/templates/Class.erb (rev 0)
+++ trunk/ruby/templates/Class.erb 2006-09-05 14:56:29 UTC (rev 74)
@@ -0,0 +1,10 @@
+package <%= package %> {
+ import <%= if(extends?) extends %>
+
+ public class ClassName <%= if(extends?) %> extends <% classname end %>{
+
+ public function <%= classname %>() {
+ super();
+ }
+ }
+}
Added: trunk/ruby/templates/TestCase.erb
===================================================================
--- trunk/ruby/templates/TestCase.erb (rev 0)
+++ trunk/ruby/templates/TestCase.erb 2006-09-05 14:56:29 UTC (rev 74)
@@ -0,0 +1,29 @@
+package lifebin.controls {
+ import asunit.framework.TestCase;
+
+ public class <%= classname %> extends TestCase {
+ private var instance:<%= classname %>;
+
+ public function <%= classname %>Test(testMethod:String = null) {
+ super(testMethod);
+ }
+
+ protected override function setUp():void {
+ super.setUp();
+ instance = new <%= classname %>();
+ }
+
+ protected override function tearDown():void {
+ super.tearDown();
+ instance = null;
+ }
+
+ public function testInstantiated():void {
+ assertTrue("<%= classname %> instantiated", instance is <%= classname %>);
+ }
+
+ public function test():void {
+ assertTrue('default failing test', false);
+ }
+ }
+}
Added: trunk/ruby/templates/TestRunner.erb
===================================================================
--- trunk/ruby/templates/TestRunner.erb (rev 0)
+++ trunk/ruby/templates/TestRunner.erb 2006-09-05 14:56:29 UTC (rev 74)
@@ -0,0 +1,17 @@
+<?xml version="1.0" encoding="utf-8"?>
+<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" initialize="start()">
+ <mx:Style source="css/<%= @project %>.css"/>
+ <mx:Script>
+ <![CDATA[
+ import asunit.textui.FlexTestRunner;
+ private var runner:FlexTestRunner;
+
+ public function start():void {
+ runner = new FlexTestRunner();
+ rawChildren.addChild(runner);
+ runner.start(AllTests, null, true);
+ }
+
+ ]]>
+ </mx:Script>
+</mx:Application>
Added: trunk/ruby/templates/TestSuite.erb
===================================================================
--- trunk/ruby/templates/TestSuite.erb (rev 0)
+++ trunk/ruby/templates/TestSuite.erb 2006-09-05 14:56:29 UTC (rev 74)
@@ -0,0 +1,15 @@
+package lifebin.controls {
+ import asunit.framework.TestSuite;
+ import lifebin.controls.DayViewTest;
+ import lifebin.controls.EventViewTest;
+ import lifebin.controls.MultiDayViewTest;
+
+ public class AllTests extends TestSuite {
+
+ public function AllTests() {
+ addTest(new lifebin.controls.DayViewTest());
+ addTest(new lifebin.controls.EventViewTest());
+ addTest(new lifebin.controls.MultiDayViewTest());
+ }
+ }
+}
Added: trunk/ruby/templates/VisualTestCase.erb
===================================================================
--- trunk/ruby/templates/VisualTestCase.erb (rev 0)
+++ trunk/ruby/templates/VisualTestCase.erb 2006-09-05 14:56:29 UTC (rev 74)
@@ -0,0 +1,97 @@
+package lifebin.controls {
+ import asunit.framework.TestCase;
+
+ import flash.display.DisplayObject;
+ import flash.utils.getTimer;
+
+ import lifebin.data.IStitch;
+ import lifebin.data.Stitch;
+ import lifebin.layout.Component;
+ import lifebin.layout.LifebinLayoutTestCase;
+
+ import mx.collections.ArrayCollection;
+ import mx.collections.IList;
+ import mx.collections.IViewCursor;
+ import mx.containers.HBox;
+ import mx.controls.Button;
+ import mx.controls.listClasses.IListItemRenderer;
+ import mx.controls.listClasses.ListBase;
+ import mx.core.ComponentDescriptor;
+ import mx.core.Container;
+ import mx.core.IDataRenderer;
+ import mx.core.UIComponent;
+
+ public class DayViewTest extends LifebinLayoutTestCase {
+ private var instance:DayView;
+ private var instances:Array;
+ private var instanceCount:Number = 1;
+
+ public function DayViewTest(testMethod:String = null) {
+ super(testMethod);
+ }
+
+ protected override function setUp():void {
+ super.setUp();
+ container = buildHBox()
+ instances = new Array();
+ for(var i:Number = 0; i < instanceCount; i++) {
+ instances.push(container.addChild(new DayView()));
+ }
+ instance = instances[0];
+ }
+
+ protected function setSimpleDataProvider(instance:ListBase):void {
+ instance.dataProvider = buildSimpleData();
+ }
+
+ protected function buildSimpleData():Array {
+ var list:Array = new Array();
+ var record:IStitch;
+ record = getStitch("one");
+ list.push(record);
+ record = getStitch("two", new Date(), null, "my description is not so long...");
+ list.push(record);
+ record = getStitch("three", new Date());
+ list.push(record);
+ record = getStitch("four", new Date());
+ list.push(record);
+ return list;
+ }
+
+ protected function getStitch(title:String, start:Date = null, end:Date = null, description:String = null):IStitch {
+ var record:IStitch = new Stitch();
+ title = (title) ? title : "Default Title";
+ start = (start) ? start : new Date();
+ end = (end) ? end : new Date();
+ record.title = title;
+ record.description = description;
+ record.start = start;
+ record.end = end;
+ return record;
+ }
+
+ protected override function tearDown():void {
+ super.tearDown();
+ instance = null;
+ }
+
+ public function testInstantiated():void {
+ assertTrue("DayView instantiated", instance is DayView);
+ }
+
+ public function testSimpleDataProvider():void {
+ var dp:Array = buildSimpleData();
+ instance.dataProvider = dp;
+ dp = instance.dataProvider;
+ assertTrue(dp.length == 4);
+ }
+
+ public function testBuildEvents():void {
+ var dp:Array = buildSimpleData();
+ var start:Number = getTimer();
+ for(var i:Number = 0; i < instances.length; i++) {
+ instances[i].dataProvider = dp;
+ }
+ }
+ }
+}
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
|
|
From: <luk...@us...> - 2006-09-20 18:43:51
|
Revision: 106
http://svn.sourceforge.net/asunit/?rev=106&view=rev
Author: lukebayes
Date: 2006-09-20 11:42:22 -0700 (Wed, 20 Sep 2006)
Log Message:
-----------
worked on the ruby project tools
Modified Paths:
--------------
trunk/ruby/src/asunit
trunk/ruby/src/asunit_arguments.rb
trunk/ruby/src/template_resolver.rb
trunk/ruby/src/templates/TestCase.erb
Added Paths:
-----------
trunk/ruby/demo/bin/
trunk/ruby/demo/bin/AC_OETags.js
trunk/ruby/demo/bin/AsUnitRubyDemo-debug.html
trunk/ruby/demo/bin/AsUnitRubyDemo-debug.swf
trunk/ruby/demo/bin/AsUnitRubyDemo.html
trunk/ruby/demo/bin/AsUnitRubyDemo.swf
trunk/ruby/demo/bin/history.htm
trunk/ruby/demo/bin/history.js
trunk/ruby/demo/bin/history.swf
trunk/ruby/demo/bin/playerProductInstall.swf
trunk/ruby/demo/src/
trunk/ruby/demo/src/AsUnitRubyDemo.mxml
trunk/ruby/demo/src/lifebin/
trunk/ruby/demo/src/lifebin/display/
trunk/ruby/demo/src/lifebin/display/Component.as
trunk/ruby/demo/src/lifebin/display/Container.as
trunk/ruby/demo/test/
trunk/ruby/demo/test/lifebin/
trunk/ruby/demo/test/lifebin/display/
trunk/ruby/demo/test/lifebin/display/ComponentTest.as
trunk/ruby/demo/test/lifebin/display/ContainerTest.as
trunk/ruby/src/asunit_application.rb
Removed Paths:
-------------
trunk/ruby/src/asunit.rb
Added: trunk/ruby/demo/bin/AC_OETags.js
===================================================================
--- trunk/ruby/demo/bin/AC_OETags.js (rev 0)
+++ trunk/ruby/demo/bin/AC_OETags.js 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,269 @@
+// Flash Player Version Detection - Rev 1.5
+// Detect Client Browser type
+// Copyright(c) 2005-2006 Adobe Macromedia Software, LLC. All rights reserved.
+var isIE = (navigator.appVersion.indexOf("MSIE") != -1) ? true : false;
+var isWin = (navigator.appVersion.toLowerCase().indexOf("win") != -1) ? true : false;
+var isOpera = (navigator.userAgent.indexOf("Opera") != -1) ? true : false;
+
+function ControlVersion()
+{
+ var version;
+ var axo;
+ var e;
+
+ // NOTE : new ActiveXObject(strFoo) throws an exception if strFoo isn't in the registry
+
+ try {
+ // version will be set for 7.X or greater players
+ axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");
+ version = axo.GetVariable("$version");
+ } catch (e) {
+ }
+
+ if (!version)
+ {
+ try {
+ // version will be set for 6.X players only
+ axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
+
+ // installed player is some revision of 6.0
+ // GetVariable("$version") crashes for versions 6.0.22 through 6.0.29,
+ // so we have to be careful.
+
+ // default to the first public version
+ version = "WIN 6,0,21,0";
+
+ // throws if AllowScripAccess does not exist (introduced in 6.0r47)
+ axo.AllowScriptAccess = "always";
+
+ // safe to call for 6.0r47 or greater
+ version = axo.GetVariable("$version");
+
+ } catch (e) {
+ }
+ }
+
+ if (!version)
+ {
+ try {
+ // version will be set for 4.X or 5.X player
+ axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
+ version = axo.GetVariable("$version");
+ } catch (e) {
+ }
+ }
+
+ if (!version)
+ {
+ try {
+ // version will be set for 3.X player
+ axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
+ version = "WIN 3,0,18,0";
+ } catch (e) {
+ }
+ }
+
+ if (!version)
+ {
+ try {
+ // version will be set for 2.X player
+ axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash");
+ version = "WIN 2,0,0,11";
+ } catch (e) {
+ version = -1;
+ }
+ }
+
+ return version;
+}
+
+// JavaScript helper required to detect Flash Player PlugIn version information
+function GetSwfVer(){
+ // NS/Opera version >= 3 check for Flash plugin in plugin array
+ var flashVer = -1;
+
+ if (navigator.plugins != null && navigator.plugins.length > 0) {
+ if (navigator.plugins["Shockwave Flash 2.0"] || navigator.plugins["Shockwave Flash"]) {
+ var swVer2 = navigator.plugins["Shockwave Flash 2.0"] ? " 2.0" : "";
+ var flashDescription = navigator.plugins["Shockwave Flash" + swVer2].description;
+ var descArray = flashDescription.split(" ");
+ var tempArrayMajor = descArray[2].split(".");
+ var versionMajor = tempArrayMajor[0];
+ var versionMinor = tempArrayMajor[1];
+ if ( descArray[3] != "" ) {
+ tempArrayMinor = descArray[3].split("r");
+ } else {
+ tempArrayMinor = descArray[4].split("r");
+ }
+ var versionRevision = tempArrayMinor[1] > 0 ? tempArrayMinor[1] : 0;
+ var flashVer = versionMajor + "." + versionMinor + "." + versionRevision;
+ }
+ }
+ // MSN/WebTV 2.6 supports Flash 4
+ else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.6") != -1) flashVer = 4;
+ // WebTV 2.5 supports Flash 3
+ else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.5") != -1) flashVer = 3;
+ // older WebTV supports Flash 2
+ else if (navigator.userAgent.toLowerCase().indexOf("webtv") != -1) flashVer = 2;
+ else if ( isIE && isWin && !isOpera ) {
+ flashVer = ControlVersion();
+ }
+ return flashVer;
+}
+
+// When called with reqMajorVer, reqMinorVer, reqRevision returns true if that version or greater is available
+function DetectFlashVer(reqMajorVer, reqMinorVer, reqRevision)
+{
+ versionStr = GetSwfVer();
+ if (versionStr == -1 ) {
+ return false;
+ } else if (versionStr != 0) {
+ if(isIE && isWin && !isOpera) {
+ // Given "WIN 2,0,0,11"
+ tempArray = versionStr.split(" "); // ["WIN", "2,0,0,11"]
+ tempString = tempArray[1]; // "2,0,0,11"
+ versionArray = tempString.split(","); // ['2', '0', '0', '11']
+ } else {
+ versionArray = versionStr.split(".");
+ }
+ var versionMajor = versionArray[0];
+ var versionMinor = versionArray[1];
+ var versionRevision = versionArray[2];
+
+ // is the major.revision >= requested major.revision AND the minor version >= requested minor
+ if (versionMajor > parseFloat(reqMajorVer)) {
+ return true;
+ } else if (versionMajor == parseFloat(reqMajorVer)) {
+ if (versionMinor > parseFloat(reqMinorVer))
+ return true;
+ else if (versionMinor == parseFloat(reqMinorVer)) {
+ if (versionRevision >= parseFloat(reqRevision))
+ return true;
+ }
+ }
+ return false;
+ }
+}
+
+function AC_AddExtension(src, ext)
+{
+ if (src.indexOf('?') != -1)
+ return src.replace(/\?/, ext+'?');
+ else
+ return src + ext;
+}
+
+function AC_Generateobj(objAttrs, params, embedAttrs)
+{
+ var str = '';
+ if (isIE && isWin && !isOpera)
+ {
+ str += '<object ';
+ for (var i in objAttrs)
+ str += i + '="' + objAttrs[i] + '" ';
+ for (var i in params)
+ str += '><param name="' + i + '" value="' + params[i] + '" /> ';
+ str += '></object>';
+ } else {
+ str += '<embed ';
+ for (var i in embedAttrs)
+ str += i + '="' + embedAttrs[i] + '" ';
+ str += '> </embed>';
+ }
+
+ document.write(str);
+}
+
+function AC_FL_RunContent(){
+ var ret =
+ AC_GetArgs
+ ( arguments, ".swf", "movie", "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
+ , "application/x-shockwave-flash"
+ );
+ AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs);
+}
+
+function AC_GetArgs(args, ext, srcParamName, classid, mimeType){
+ var ret = new Object();
+ ret.embedAttrs = new Object();
+ ret.params = new Object();
+ ret.objAttrs = new Object();
+ for (var i=0; i < args.length; i=i+2){
+ var currArg = args[i].toLowerCase();
+
+ switch (currArg){
+ case "classid":
+ break;
+ case "pluginspage":
+ ret.embedAttrs[args[i]] = args[i+1];
+ break;
+ case "src":
+ case "movie":
+ args[i+1] = AC_AddExtension(args[i+1], ext);
+ ret.embedAttrs["src"] = args[i+1];
+ ret.params[srcParamName] = args[i+1];
+ break;
+ case "onafterupdate":
+ case "onbeforeupdate":
+ case "onblur":
+ case "oncellchange":
+ case "onclick":
+ case "ondblClick":
+ case "ondrag":
+ case "ondragend":
+ case "ondragenter":
+ case "ondragleave":
+ case "ondragover":
+ case "ondrop":
+ case "onfinish":
+ case "onfocus":
+ case "onhelp":
+ case "onmousedown":
+ case "onmouseup":
+ case "onmouseover":
+ case "onmousemove":
+ case "onmouseout":
+ case "onkeypress":
+ case "onkeydown":
+ case "onkeyup":
+ case "onload":
+ case "onlosecapture":
+ case "onpropertychange":
+ case "onreadystatechange":
+ case "onrowsdelete":
+ case "onrowenter":
+ case "onrowexit":
+ case "onrowsinserted":
+ case "onstart":
+ case "onscroll":
+ case "onbeforeeditfocus":
+ case "onactivate":
+ case "onbeforedeactivate":
+ case "ondeactivate":
+ case "type":
+ case "codebase":
+ case "id":
+ ret.objAttrs[args[i]] = args[i+1];
+ break;
+ case "width":
+ case "height":
+ case "align":
+ case "vspace":
+ case "hspace":
+ case "class":
+ case "title":
+ case "accesskey":
+ case "name":
+ case "tabindex":
+ ret.embedAttrs[args[i]] = ret.objAttrs[args[i]] = args[i+1];
+ break;
+ default:
+ ret.embedAttrs[args[i]] = ret.params[args[i]] = args[i+1];
+ }
+ }
+ ret.objAttrs["classid"] = classid;
+ if (mimeType) ret.embedAttrs["type"] = mimeType;
+ return ret;
+}
+
+
Added: trunk/ruby/demo/bin/AsUnitRubyDemo-debug.html
===================================================================
--- trunk/ruby/demo/bin/AsUnitRubyDemo-debug.html (rev 0)
+++ trunk/ruby/demo/bin/AsUnitRubyDemo-debug.html 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,107 @@
+<!-- saved from url=(0014)about:internet -->
+<html lang="en">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+<title></title>
+<script src="AC_OETags.js" language="javascript"></script>
+<style>
+body { margin: 0px; overflow:hidden }
+</style>
+<script language="JavaScript" type="text/javascript">
+<!--
+// -----------------------------------------------------------------------------
+// Globals
+// Major version of Flash required
+var requiredMajorVersion = 9;
+// Minor version of Flash required
+var requiredMinorVersion = 0;
+// Minor version of Flash required
+var requiredRevision = 0;
+// -----------------------------------------------------------------------------
+// -->
+</script>
+</head>
+
+<body scroll="no">
+<script language="JavaScript" type="text/javascript" src="history.js"></script>
+<script language="JavaScript" type="text/javascript">
+<!--
+// Version check for the Flash Player that has the ability to start Player Product Install (6.0r65)
+var hasProductInstall = DetectFlashVer(6, 0, 65);
+
+// Version check based upon the values defined in globals
+var hasRequestedVersion = DetectFlashVer(requiredMajorVersion, requiredMinorVersion, requiredRevision);
+
+
+// Check to see if a player with Flash Product Install is available and the version does not meet the requirements for playback
+if ( hasProductInstall && !hasRequestedVersion ) {
+ // MMdoctitle is the stored document.title value used by the installation process to close the window that started the process
+ // This is necessary in order to close browser windows that are still utilizing the older version of the player after installation has completed
+ // DO NOT MODIFY THE FOLLOWING FOUR LINES
+ // Location visited after installation is complete if installation is required
+ var MMPlayerType = (isIE == true) ? "ActiveX" : "PlugIn";
+ var MMredirectURL = window.location;
+ document.title = document.title.slice(0, 47) + " - Flash Player Installation";
+ var MMdoctitle = document.title;
+
+ AC_FL_RunContent(
+ "src", "playerProductInstall",
+ "FlashVars", "MMredirectURL="+MMredirectURL+'&MMplayerType='+MMPlayerType+'&MMdoctitle='+MMdoctitle+"",
+ "width", "100%",
+ "height", "100%",
+ "align", "middle",
+ "id", "AsUnitRubyDemo",
+ "quality", "high",
+ "bgcolor", "#869ca7",
+ "name", "AsUnitRubyDemo",
+ "allowScriptAccess","sameDomain",
+ "type", "application/x-shockwave-flash",
+ "pluginspage", "http://www.adobe.com/go/getflashplayer"
+ );
+} else if (hasRequestedVersion) {
+ // if we've detected an acceptable version
+ // embed the Flash Content SWF when all tests are passed
+ AC_FL_RunContent(
+ "src", "AsUnitRubyDemo-debug",
+ "width", "100%",
+ "height", "100%",
+ "align", "middle",
+ "id", "AsUnitRubyDemo",
+ "quality", "high",
+ "bgcolor", "#869ca7",
+ "name", "AsUnitRubyDemo",
+ "flashvars",'historyUrl=history.htm%3F&lconid=' + lc_id + '',
+ "allowScriptAccess","sameDomain",
+ "type", "application/x-shockwave-flash",
+ "pluginspage", "http://www.adobe.com/go/getflashplayer"
+ );
+ } else { // flash is too old or we can't detect the plugin
+ var alternateContent = 'Alternate HTML content should be placed here. '
+ + 'This content requires the Adobe Flash Player. '
+ + '<a href=http://www.adobe.com/go/getflash/>Get Flash</a>';
+ document.write(alternateContent); // insert non-flash content
+ }
+// -->
+</script>
+<noscript>
+ <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
+ id="AsUnitRubyDemo" width="100%" height="100%"
+ codebase="http://fpdownload.macromedia.com/get/flashplayer/current/swflash.cab">
+ <param name="movie" value="AsUnitRubyDemo-debug.swf" />
+ <param name="quality" value="high" />
+ <param name="bgcolor" value="#869ca7" />
+ <param name="allowScriptAccess" value="sameDomain" />
+ <embed src="AsUnitRubyDemo-debug.swf" quality="high" bgcolor="#869ca7"
+ width="100%" height="100%" name="AsUnitRubyDemo" align="middle"
+ play="true"
+ loop="false"
+ quality="high"
+ allowScriptAccess="sameDomain"
+ type="application/x-shockwave-flash"
+ pluginspage="http://www.adobe.com/go/getflashplayer">
+ </embed>
+ </object>
+</noscript>
+<iframe name="_history" src="history.htm" frameborder="0" scrolling="no" width="22" height="0"></iframe>
+</body>
+</html>
Added: trunk/ruby/demo/bin/AsUnitRubyDemo-debug.swf
===================================================================
(Binary files differ)
Property changes on: trunk/ruby/demo/bin/AsUnitRubyDemo-debug.swf
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Added: trunk/ruby/demo/bin/AsUnitRubyDemo.html
===================================================================
--- trunk/ruby/demo/bin/AsUnitRubyDemo.html (rev 0)
+++ trunk/ruby/demo/bin/AsUnitRubyDemo.html 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,107 @@
+<!-- saved from url=(0014)about:internet -->
+<html lang="en">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+<title></title>
+<script src="AC_OETags.js" language="javascript"></script>
+<style>
+body { margin: 0px; overflow:hidden }
+</style>
+<script language="JavaScript" type="text/javascript">
+<!--
+// -----------------------------------------------------------------------------
+// Globals
+// Major version of Flash required
+var requiredMajorVersion = 9;
+// Minor version of Flash required
+var requiredMinorVersion = 0;
+// Minor version of Flash required
+var requiredRevision = 0;
+// -----------------------------------------------------------------------------
+// -->
+</script>
+</head>
+
+<body scroll="no">
+<script language="JavaScript" type="text/javascript" src="history.js"></script>
+<script language="JavaScript" type="text/javascript">
+<!--
+// Version check for the Flash Player that has the ability to start Player Product Install (6.0r65)
+var hasProductInstall = DetectFlashVer(6, 0, 65);
+
+// Version check based upon the values defined in globals
+var hasRequestedVersion = DetectFlashVer(requiredMajorVersion, requiredMinorVersion, requiredRevision);
+
+
+// Check to see if a player with Flash Product Install is available and the version does not meet the requirements for playback
+if ( hasProductInstall && !hasRequestedVersion ) {
+ // MMdoctitle is the stored document.title value used by the installation process to close the window that started the process
+ // This is necessary in order to close browser windows that are still utilizing the older version of the player after installation has completed
+ // DO NOT MODIFY THE FOLLOWING FOUR LINES
+ // Location visited after installation is complete if installation is required
+ var MMPlayerType = (isIE == true) ? "ActiveX" : "PlugIn";
+ var MMredirectURL = window.location;
+ document.title = document.title.slice(0, 47) + " - Flash Player Installation";
+ var MMdoctitle = document.title;
+
+ AC_FL_RunContent(
+ "src", "playerProductInstall",
+ "FlashVars", "MMredirectURL="+MMredirectURL+'&MMplayerType='+MMPlayerType+'&MMdoctitle='+MMdoctitle+"",
+ "width", "100%",
+ "height", "100%",
+ "align", "middle",
+ "id", "AsUnitRubyDemo",
+ "quality", "high",
+ "bgcolor", "#869ca7",
+ "name", "AsUnitRubyDemo",
+ "allowScriptAccess","sameDomain",
+ "type", "application/x-shockwave-flash",
+ "pluginspage", "http://www.adobe.com/go/getflashplayer"
+ );
+} else if (hasRequestedVersion) {
+ // if we've detected an acceptable version
+ // embed the Flash Content SWF when all tests are passed
+ AC_FL_RunContent(
+ "src", "AsUnitRubyDemo",
+ "width", "100%",
+ "height", "100%",
+ "align", "middle",
+ "id", "AsUnitRubyDemo",
+ "quality", "high",
+ "bgcolor", "#869ca7",
+ "name", "AsUnitRubyDemo",
+ "flashvars",'historyUrl=history.htm%3F&lconid=' + lc_id + '',
+ "allowScriptAccess","sameDomain",
+ "type", "application/x-shockwave-flash",
+ "pluginspage", "http://www.adobe.com/go/getflashplayer"
+ );
+ } else { // flash is too old or we can't detect the plugin
+ var alternateContent = 'Alternate HTML content should be placed here. '
+ + 'This content requires the Adobe Flash Player. '
+ + '<a href=http://www.adobe.com/go/getflash/>Get Flash</a>';
+ document.write(alternateContent); // insert non-flash content
+ }
+// -->
+</script>
+<noscript>
+ <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
+ id="AsUnitRubyDemo" width="100%" height="100%"
+ codebase="http://fpdownload.macromedia.com/get/flashplayer/current/swflash.cab">
+ <param name="movie" value="AsUnitRubyDemo.swf" />
+ <param name="quality" value="high" />
+ <param name="bgcolor" value="#869ca7" />
+ <param name="allowScriptAccess" value="sameDomain" />
+ <embed src="AsUnitRubyDemo.swf" quality="high" bgcolor="#869ca7"
+ width="100%" height="100%" name="AsUnitRubyDemo" align="middle"
+ play="true"
+ loop="false"
+ quality="high"
+ allowScriptAccess="sameDomain"
+ type="application/x-shockwave-flash"
+ pluginspage="http://www.adobe.com/go/getflashplayer">
+ </embed>
+ </object>
+</noscript>
+<iframe name="_history" src="history.htm" frameborder="0" scrolling="no" width="22" height="0"></iframe>
+</body>
+</html>
Added: trunk/ruby/demo/bin/AsUnitRubyDemo.swf
===================================================================
(Binary files differ)
Property changes on: trunk/ruby/demo/bin/AsUnitRubyDemo.swf
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Added: trunk/ruby/demo/bin/history.htm
===================================================================
--- trunk/ruby/demo/bin/history.htm (rev 0)
+++ trunk/ruby/demo/bin/history.htm 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,21 @@
+<html>
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
+<script type='text/javascript' language='JavaScript1.2' charset='utf-8'>
+var v = new top.Vars(top.getSearch(window));
+var fv = v.toString('$_');
+</script>
+</head>
+<body >
+<script type='text/javascript' language='JavaScript1.2' charset='utf-8'>
+document.writeln('<object id=\"utility\" name=\" \" classid=\"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000\" codebase=\"" + activexDownloadURL + "#version=7,0,14,0\" width=\"100\" height=\"50\">');
+document.writeln('<param name=\"movie\" value=\"history.swf\" />');
+document.writeln('<param name=\"FlashVars\" value=\"'+fv+'&$_lconid='+top.lc_id+'\"/>');
+document.writeln('<param name=\"quality\" value=\"high\" />');
+document.writeln('<param name=\"bgcolor\" value=\"#FFFFFF\" />');
+document.writeln('<param name=\"profile\" value=\"false\" />');
+document.writeln('<embed id=\"utilityEmbed\" name=\"history.swf\" src=\"history.swf\" type=\"application/x-shockwave-flash\" flashvars=\"'+fv+'&$_lconid='+top.lc_id+'\" profile=\"false\" quality=\"high\" bgcolor=\"#FFFFFF\" width=\"100\" height=\"50\" align=\"\" pluginspage=\"" + pluginDownloadURL + "\"></embed>');
+document.writeln('</object>');
+</script>
+</body>
+</html>
\ No newline at end of file
Added: trunk/ruby/demo/bin/history.js
===================================================================
--- trunk/ruby/demo/bin/history.js (rev 0)
+++ trunk/ruby/demo/bin/history.js 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,48 @@
+// $Revision: 1.49 $
+// Vars
+Vars = function(qStr) {
+ this.numVars = 0;
+ if(qStr != null) {
+ var nameValue, name;
+ var pairs = qStr.split('&');
+ var pairLen = pairs.length;
+ for(var i = 0; i < pairLen; i++) {
+ var pair = pairs[i];
+ if( (pair.indexOf('=')!= -1) && (pair.length > 3) ) {
+ var nameValue = pair.split('=');
+ var name = nameValue[0];
+ var value = nameValue[1];
+ if(this[name] == null && name.length > 0 && value.length > 0) {
+ this[name] = value;
+ this.numVars++;
+ }
+ }
+ }
+ }
+}
+Vars.prototype.toString = function(pre) {
+ var result = '';
+ if(pre == null) { pre = ''; }
+ for(var i in this) {
+ if(this[i] != null && typeof(this[i]) != 'object' && typeof(this[i]) != 'function' && i != 'numVars') {
+ result += pre + i + '=' + this[i] + '&';
+ }
+ }
+ if(result.length > 0) result = result.substr(0, result.length-1);
+ return result;
+}
+function getSearch(wRef) {
+ var searchStr = '';
+ if(wRef.location.search.length > 1) {
+ searchStr = new String(wRef.location.search);
+ searchStr = searchStr.substring(1, searchStr.length);
+ }
+ return searchStr;
+}
+var lc_id = Math.floor(Math.random() * 100000).toString(16);
+if (this != top)
+{
+ top.Vars = Vars;
+ top.getSearch = getSearch;
+ top.lc_id = lc_id;
+}
Added: trunk/ruby/demo/bin/history.swf
===================================================================
(Binary files differ)
Property changes on: trunk/ruby/demo/bin/history.swf
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Added: trunk/ruby/demo/bin/playerProductInstall.swf
===================================================================
(Binary files differ)
Property changes on: trunk/ruby/demo/bin/playerProductInstall.swf
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Added: trunk/ruby/demo/src/AsUnitRubyDemo.mxml
===================================================================
--- trunk/ruby/demo/src/AsUnitRubyDemo.mxml (rev 0)
+++ trunk/ruby/demo/src/AsUnitRubyDemo.mxml 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,4 @@
+<?xml version="1.0" encoding="utf-8"?>
+<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
+ <mx:Label text="Hello World" />
+</mx:Application>
Added: trunk/ruby/demo/src/lifebin/display/Component.as
===================================================================
--- trunk/ruby/demo/src/lifebin/display/Component.as (rev 0)
+++ trunk/ruby/demo/src/lifebin/display/Component.as 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,10 @@
+
+package lifebin.display {
+
+ public class Component {
+
+ public function Component() {
+ super();
+ }
+ }
+}
Added: trunk/ruby/demo/src/lifebin/display/Container.as
===================================================================
--- trunk/ruby/demo/src/lifebin/display/Container.as (rev 0)
+++ trunk/ruby/demo/src/lifebin/display/Container.as 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,10 @@
+
+package lifebin.display {
+
+ public class Container {
+
+ public function Container() {
+ super();
+ }
+ }
+}
Added: trunk/ruby/demo/test/lifebin/display/ComponentTest.as
===================================================================
--- trunk/ruby/demo/test/lifebin/display/ComponentTest.as (rev 0)
+++ trunk/ruby/demo/test/lifebin/display/ComponentTest.as 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,29 @@
+package lifebin.display {
+ import asunit.framework.TestCase;
+
+ public class ComponentTest extends TestCase {
+ private var instance:Component;
+
+ public function ComponentTest(testMethod:String = null) {
+ super(testMethod);
+ }
+
+ protected override function setUp():void {
+ super.setUp();
+ instance = new Component();
+ }
+
+ protected override function tearDown():void {
+ super.tearDown();
+ instance = null;
+ }
+
+ public function testInstantiated():void {
+ assertTrue("ComponentTest instantiated", instance is Component);
+ }
+
+ public function test():void {
+ assertTrue("ComponentTest default failing test", false);
+ }
+ }
+}
Added: trunk/ruby/demo/test/lifebin/display/ContainerTest.as
===================================================================
--- trunk/ruby/demo/test/lifebin/display/ContainerTest.as (rev 0)
+++ trunk/ruby/demo/test/lifebin/display/ContainerTest.as 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,31 @@
+package lifebin.display {
+ import asunit.framework.TestCase;
+
+ public class ContainerTest extends TestCase {
+ private var instance:Container;
+
+ public function ContainerTest(testMethod:String = null) {
+ super(testMethod);
+ }
+
+ protected override function setUp():void {
+ super.setUp();
+ instance = new Container();
+ addChild(instance);
+ }
+
+ protected override function tearDown():void {
+ super.tearDown();
+ removeChild(instance);
+ instance = null;
+ }
+
+ public function testInstantiated():void {
+ assertTrue("ContainerTest instantiated", instance is Container);
+ }
+
+ public function test():void {
+ assertTrue("ContainerTest default failing test", false);
+ }
+ }
+}
Modified: trunk/ruby/src/asunit
===================================================================
--- trunk/ruby/src/asunit 2006-09-20 18:24:28 UTC (rev 105)
+++ trunk/ruby/src/asunit 2006-09-20 18:42:22 UTC (rev 106)
@@ -1,5 +1,7 @@
#!/bin/ruby
+$:.push('~/projects/asunit/ruby/src')
+
module AsUnit
# ------------------------------------------------------------------
# COPIED FROM RAKE! Rake module singleton methods.
@@ -46,7 +48,7 @@
end
end
-require 'asunit.rb'
+require 'asunit_application'
if __FILE__ == $0 then
AsUnit::Application.new
Deleted: trunk/ruby/src/asunit.rb
===================================================================
--- trunk/ruby/src/asunit.rb 2006-09-20 18:24:28 UTC (rev 105)
+++ trunk/ruby/src/asunit.rb 2006-09-20 18:42:22 UTC (rev 106)
@@ -1,71 +0,0 @@
-#!/bin/ruby
-
-module AsUnit
- CLASS_TEMPLATE = 'Class.erb'
- TEST_TEMPLATE = 'TestCase.erb'
- PROJECT_FILE_NAME = '.asunit'
-
- require 'yaml'
- require 'optparse'
- require 'settings'
- require 'create_class'
- require 'asunit_arguments'
-
- class Application
-
- def initialize
- super
- arguments = AsUnitArguments.new(ARGV)
- project_file = get_project_file Dir.pwd
- prefs = YAML.load(project_file.read)
- settings = AsUnit::Settings.new(prefs)
-
- results = Array.new
- arguments.classnames.each { |name|
- if(name.ends_with? "Test")
- begin
- create_class(name, settings, TEST_TEMPLATE, arguments)
- rescue Exception => e
- results.push(e)
- end
- else
- begin
- create_class(name, settings, AsUnit::CLASS_TEMPLATE, arguments)
- rescue Exception => e
- results.push(e)
- end
- begin
- create_class(name + "Test", settings, AsUnit::TEST_TEMPLATE, arguments)
- rescue Exception => e
- results.push(e)
- end
- end
- }
- if(results.length > 0)
- puts results.join("\n")
- end
- end
-
- def create_class(name, settings, template, arguments)
- begin
- class_creator = AsUnit::CreateClass.new(name, settings, template)
- class_creator.run(arguments)
- puts 'File Created at: ' + class_creator.final_path
- return nil
- rescue Exception => e
- raise e
- end
- end
-
- def get_project_file(dir)
- if(dir == '/')
- raise 'Project file not found, please create a new asunit project by typing "asunit -create-project [-src, -test, -templates]"'
- end
- Dir.chdir dir
- if(File.exists? AsUnit::PROJECT_FILE_NAME)
- return File.open(AsUnit::PROJECT_FILE_NAME, 'r')
- end
- get_project_file(File.dirname(dir))
- end
- end
-end
Added: trunk/ruby/src/asunit_application.rb
===================================================================
--- trunk/ruby/src/asunit_application.rb (rev 0)
+++ trunk/ruby/src/asunit_application.rb 2006-09-20 18:42:22 UTC (rev 106)
@@ -0,0 +1,83 @@
+#!/bin/ruby
+
+module AsUnit
+ CLASS_TEMPLATE = 'Class.erb'
+ TEST_TEMPLATE = 'TestCase.erb'
+ PROJECT_FILE_NAME = '.asunit'
+ FLEX_PROJECT_FILE_NAME = '.actionScriptProperties'
+
+ require 'yaml'
+ require 'optparse'
+ require 'settings'
+ require 'create_class'
+ require 'asunit_arguments'
+
+ class Application
+
+ def initialize
+ super
+ arguments = AsUnitArguments.new(ARGV)
+ @starting_dir = Dir.pwd
+ project_file = get_project_file(Dir.pwd, AsUnit::PROJECT_FILE_NAME)
+ if(project_file.nil?)
+ Dir.chdir @starting_dir
+ project_file = get_project_file(Dir.pwd, AsUnit::PROJECT_FILE_NAME)
+ end
+
+ if(project_file.nil?)
+ puts 'No project file found!'
+ end
+
+ prefs = YAML.load(project_file.read)
+ settings = AsUnit::Settings.new(prefs)
+
+ results = Array.new
+ arguments.classnames.each { |name|
+ if(name.ends_with? "Test")
+ begin
+ create_clas...
[truncated message content] |
|
From: <luk...@us...> - 2006-09-06 02:28:18
|
Revision: 76
http://svn.sourceforge.net/asunit/?rev=76&view=rev
Author: lukebayes
Date: 2006-09-05 19:28:09 -0700 (Tue, 05 Sep 2006)
Log Message:
-----------
moved templates into src directory
Added Paths:
-----------
trunk/ruby/src/templates/
Removed Paths:
-------------
trunk/ruby/templates/
Copied: trunk/ruby/src/templates (from rev 74, trunk/ruby/templates)
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
|
|
From: <luk...@us...> - 2006-09-06 06:01:09
|
Revision: 82
http://svn.sourceforge.net/asunit/?rev=82&view=rev
Author: lukebayes
Date: 2006-09-05 23:01:00 -0700 (Tue, 05 Sep 2006)
Log Message:
-----------
almost have it sort of working...
Modified Paths:
--------------
trunk/ruby/src/asunit.rb
trunk/ruby/src/settings.rb
trunk/ruby/src/templates/TestCase.erb
Added Paths:
-----------
trunk/ruby/.asunit
Added: trunk/ruby/.asunit
===================================================================
--- trunk/ruby/.asunit (rev 0)
+++ trunk/ruby/.asunit 2006-09-06 06:01:00 UTC (rev 82)
@@ -0,0 +1,7 @@
+---
+project: Lifebin
+src: demo/src
+test: demo/test
+templates: src/templates
+file_extension: .as
+classpath:
\ No newline at end of file
Modified: trunk/ruby/src/asunit.rb
===================================================================
--- trunk/ruby/src/asunit.rb 2006-09-06 05:26:38 UTC (rev 81)
+++ trunk/ruby/src/asunit.rb 2006-09-06 06:01:00 UTC (rev 82)
@@ -39,36 +39,48 @@
end
end
+ require 'yaml'
require 'optparse'
+ require 'settings'
+ require 'create_class'
class Application
@@PROJECT_FILE_NAME = '.asunit'
-
+ @@CLASS_TEMPLATE = 'Class.erb'
+ @@TEST_TEMPLATE = 'TestCase.erb'
+
def initialize
super
arguments = AsUnitArguments.new(ARGV)
project_file = get_project_file Dir.pwd
- puts 'pf dir: ' + Dir.pwd
- puts 'pf: ' + project_file.read
+ prefs = YAML.load(project_file.read)
+ settings = AsUnit::Settings.new(prefs)
+
arguments.classnames.each { |name|
- create_class name
+ if(name.ends_with? "Test")
+ create_class(name, settings, @@TEST_TEMPLATE)
+ else
+ create_class(name, settings, @@CLASS_TEMPLATE)
+ create_class(name + "Test", settings, @@TEST_TEMPLATE)
+ end
}
end
+ def create_class(name, settings, template)
+ created_class = AsUnit::CreateClass.new(name, settings, template)
+ created_class.run
+ end
+
def get_project_file(dir)
if(dir == '/')
- raise 'Project file not found, please create a new asunit project by typing "asunit -create-project ProjectName"'
+ raise 'Project file not found, please create a new asunit project by typing "asunit -create-project [-src, -test, -templates]"'
end
Dir.chdir dir
if(File.exists? @@PROJECT_FILE_NAME)
return File.open(@@PROJECT_FILE_NAME, 'r')
end
- get_project_file(File.dirname dir)
- end
-
- def create_class(name)
- puts 'name: ' + name
- end
+ get_project_file(File.dirname(dir))
+ end
end
class AsUnitArguments < Hash
@@ -143,6 +155,12 @@
end
end
+class String
+ def ends_with? str
+ return false
+ end
+end
+
if __FILE__ == $0 then
AsUnit::Application.new
end
Modified: trunk/ruby/src/settings.rb
===================================================================
--- trunk/ruby/src/settings.rb 2006-09-06 05:26:38 UTC (rev 81)
+++ trunk/ruby/src/settings.rb 2006-09-06 06:01:00 UTC (rev 82)
@@ -5,12 +5,26 @@
attr_accessor :src, :test, :templates, :file_extension, :directories
- def initialize
+ def initialize(hash)
@directories = ['src', 'test', 'templates', 'css', 'xml']
@src = 'src'
@test = 'test'
@templates = 'templates'
@file_extension = @@FILE_EXTENSION
+
+ if(!hash['src'].nil?)
+ @src = hash['src']
+ end
+ if(!hash['test'].nil?)
+ @test = hash['test']
+ end
+ if(!hash['templates'].nil?)
+ @templates = hash['templates']
+ end
+ if(!hash['file_extension'].nil?)
+ @file_extension = hash['file_extension']
+ end
+
end
end
end
\ No newline at end of file
Modified: trunk/ruby/src/templates/TestCase.erb
===================================================================
--- trunk/ruby/src/templates/TestCase.erb 2006-09-06 05:26:38 UTC (rev 81)
+++ trunk/ruby/src/templates/TestCase.erb 2006-09-06 06:01:00 UTC (rev 82)
@@ -1,29 +1,35 @@
-package lifebin.controls {
+package <%= package %>{
import asunit.framework.TestCase;
-
+
public class <%= classname %> extends TestCase {
private var instance:<%= classname %>;
-
- public function <%= classname %>Test(testMethod:String = null) {
+
+ public function <%= classname %>(testMethod:String = null) {
super(testMethod);
}
-
+
protected override function setUp():void {
super.setUp();
instance = new <%= classname %>();
+ <% if visual? %>
+ addChild(instance);
+ <% end %>
}
-
+
protected override function tearDown():void {
super.tearDown();
+ <% if visual? %>
+ removeChild(instance);
+ <% end %>
instance = null;
}
-
+
public function testInstantiated():void {
assertTrue("<%= classname %> instantiated", instance is <%= classname %>);
}
-
+
public function test():void {
- assertTrue('default failing test', false);
+ assertTrue("<%= classname %> default failing test", false);
}
}
}
This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.
|