views:

1876

answers:

7

Hi,

So I've followed this tutorial to setup unit testing on my app when I got a little stuck.

At bullet point 8 in that tutorial it shows this image, which is what I should be expecting when I build: alt text

However this isn't what I get when I build. I get this error message: Command /bin/sh failed with exit code 1 as well as the error message the unit test has created. Then, when I expand on the first error I get this:

PhaseScriptExecution "Run Script" "build/3D Pool.build/Debug-iphonesimulator/LogicTests.build/Script-1A6BA6AE10F28F40008AC2A8.sh"
cd "/Users/james/Desktop/FYP/3D Pool"
setenv ACTION build
setenv ALTERNATE_GROUP staff
...
setenv XCODE_VERSION_MAJOR 0300
setenv XCODE_VERSION_MINOR 0320
setenv YACC /Developer/usr/bin/yacc
/bin/sh -c "\"/Users/james/Desktop/FYP/3D Pool/build/3D Pool.build/Debug-iphonesimulator/LogicTests.build/Script-1A6BA6AE10F28F40008AC2A8.sh\""

/Developer/Tools/RunPlatformUnitTests.include:412: note: Started tests for architectures 'i386'
/Developer/Tools/RunPlatformUnitTests.include:419: note: Running tests for architecture 'i386' (GC OFF)
objc[12589]: GC: forcing GC OFF because OBJC_DISABLE_GC is set
Test Suite '/Users/james/Desktop/FYP/3D Pool/build/Debug-iphonesimulator/LogicTests.octest(Tests)' started at 2010-01-04 21:05:06 +0000
Test Suite 'LogicTests' started at 2010-01-04 21:05:06 +0000
Test Case '-[LogicTests testFail]' started.
/Users/james/Desktop/FYP/3D Pool/LogicTests.m:17: error: -[LogicTests testFail] : Must fail to succeed.
Test Case '-[LogicTests testFail]' failed (0.000 seconds).
Test Suite 'LogicTests' finished at 2010-01-04 21:05:06 +0000.
Executed 1 test, with 1 failure (0 unexpected) in 0.000 (0.000) seconds

Test Suite '/Users/james/Desktop/FYP/3D Pool/build/Debug-iphonesimulator/LogicTests.octest(Tests)' finished at 2010-01-04 21:05:06 +0000.
Executed 1 test, with 1 failure (0 unexpected) in 0.000 (0.002) seconds

/Developer/Tools/RunPlatformUnitTests.include:448: error: Failed tests for architecture 'i386' (GC OFF)
/Developer/Tools/RunPlatformUnitTests.include:462: note: Completed tests for architectures 'i386'
Command /bin/sh failed with exit code 1

Now this is very odd as it is running the tests (and succeeding as you can see my STFail firing) because if I add a different test which passes I get no errors, so the tests are working fine. But why am I getting this extra build fail?

It may also be of note that when downloading solutions/templates which should work out the box, I get the same error. I'm guessing I've set something up wrong here but I've just followed a tutorial 100% correctly!! If anyone could help I'd be very grateful!

Thanks

EDIT: According to this blog, this post and a few other websites, I'm not the only one getting this problem. It has been like this since the release of xCode 3.2, assuming the apple dev center documents and tutorials etc are pre-3.2 as well.

However some say its a known issue whereas others seem to think this was intentional. I for one would like both the extended console and in code messages, and I certainly do not like the "Command /bin/sh..." error and really think they would have documented such an update. Hopefully it will be fixed soon anyway.

UPDATE: Here's confirmation it's something changed since the release of xCode 3.2.1.

This image: alt text is from my test build using 3.2.1. This one is from an older version (3.1.4): alt text. (The project for both was unchanged).

A: 

I get the same problem

Luke
Yea like I said in the update, it turns out its changed in the latest version (3.1.4) of xCode.
ing0
+4  A: 

Have you thought about bug reporting this too Apple?

Heh, I'm not too sure this counts as a bug, I'm still not sure if it's a feature or not!!
ing0
+1  A: 

Have you tried to set the build configuration to "Debug" for the test case ?

i did that, as shown at http://nothing2fancy.com/2009/08/04/failed-tests-for-architecture-i386-gc-off/ and it worked

Thomas Joulin
Thanks for the suggestion but that's not quite what's happening on mine! The unit test's themselves are working fine, it's the message that is supposed to appear in code has gone from the most recent version of xcode, they now appear in the build results but I don't think this is intended! Which version of xcode are you using?
ing0
Version 3.2.2 Pre-release. so that might be fixed in the latest
Thomas Joulin
Possibly, I'm still on 3.2.1. Thanks for that, I'll get the current pre-release and give that a go.
ing0
Well, the 3.2 SDK was published yesterday. I didn't try Unit Tests again, but since it worked in the pre-release i'm pretty confident it will work on the stable one ;)
Thomas Joulin
A: 

I don't know it a right way or not, but it's work for me.

In General Tab of info Test Case, I add my main application executable target as a direct dependency.

And no error for ‘i386′ (GC OFF)”.

Good luck.

lufutu
Thanks for the input but it still does the same thing :(
ing0
+1  A: 

In XCode 3.2.3 I get the same problem

iainH