{ "id": "103148", "key": "TIMOB-11392", "fields": { "issuetype": { "id": "1", "description": "A problem which impairs or prevents the functions of the product.", "name": "Bug", "subtask": false }, "project": { "id": "10153", "key": "TIMOB", "name": "Titanium SDK/CLI", "projectCategory": { "id": "10100", "description": "Titanium and related SDKs used in application development", "name": "Client" } }, "fixVersions": [ { "id": "14162", "description": "Release 3.1.0", "name": "Release 3.1.0", "archived": true, "released": true, "releaseDate": "2013-04-16" }, { "id": "14165", "description": "2012 Sprint 21 API", "name": "2012 Sprint 21 API", "archived": true, "released": true, "releaseDate": "2012-10-22" }, { "id": "14273", "description": "2012 Sprint 21", "name": "2012 Sprint 21", "archived": true, "released": true, "releaseDate": "2012-10-22" } ], "resolution": { "id": "3", "description": "The problem is a duplicate of an existing issue.", "name": "Duplicate" }, "resolutiondate": "2012-10-11T23:26:14.000+0000", "created": "2012-10-11T18:53:16.000+0000", "priority": { "name": "High", "id": "2" }, "labels": [ "module_tableviewrow", "qe-and100112", "qe-testadded", "regression" ], "versions": [ { "id": "13505", "description": "Release 3.0.0", "name": "Release 3.0.0", "archived": true, "released": true, "releaseDate": "2012-12-14" } ], "issuelinks": [ { "id": "21923", "type": { "id": "10003", "name": "Relates", "inward": "relates to", "outward": "relates to" }, "outwardIssue": { "id": "91600", "key": "TIMOB-9060", "fields": { "summary": "Android: iIlegalStateException Ambiguous Z index", "status": { "description": "The issue is considered finished, the resolution is correct. Issues which are closed can be reopened.", "name": "Closed", "id": "6", "statusCategory": { "id": 3, "key": "done", "colorName": "green", "name": "Done" } }, "priority": { "name": "High", "id": "2" }, "issuetype": { "id": "1", "description": "A problem which impairs or prevents the functions of the product.", "name": "Bug", "subtask": false } } } } ], "assignee": { "name": "krowley", "key": "krowley", "displayName": "Karl Rowley", "active": true, "timeZone": "America/Los_Angeles" }, "updated": "2012-11-06T17:40:17.000+0000", "status": { "description": "The issue is considered finished, the resolution is correct. Issues which are closed can be reopened.", "name": "Closed", "id": "6", "statusCategory": { "id": 3, "key": "done", "colorName": "green", "name": "Done" } }, "components": [ { "id": "10202", "name": "Android", "description": "Android Platform" } ], "description": "Description:\r\nThe app crashes on launch.\r\nThis is a regression, does not occur on 2.1.3.\r\n\r\nLog output:\r\n{code}\r\n10-11 11:50:24.786: E/TiApplication(4067): (main) [15081,15081] Sending event: exception on thread: main msg:java.lang.NullPointerException; Titanium 3.0.0,2012/10/10 18:46,8a4b013\r\n10-11 11:50:24.786: E/TiApplication(4067): java.lang.NullPointerException\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.TiUITableView.registerForTouch(TiUITableView.java:214)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.handleGetView(TiViewProxy.java:446)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.getOrCreateView(TiViewProxy.java:415)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.forceCreateView(TiViewProxy.java:400)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.createControls(TiTableViewRowProxyItem.java:139)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.setRowData(TiTableViewRowProxyItem.java:286)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.setRowData(TiTableViewRowProxyItem.java:81)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableView$TTVListAdapter.getView(TiTableView.java:226)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.AbsListView.obtainView(AbsListView.java:2267)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.ListView.makeAndAddView(ListView.java:1769)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.ListView.fillDown(ListView.java:672)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.ListView.fillFromTop(ListView.java:733)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.ListView.layoutChildren(ListView.java:1622)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.AbsListView.onLayout(AbsListView.java:2102)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableView.onLayout(TiTableView.java:555)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat org.appcelerator.titanium.view.TiCompositeLayout.onLayout(TiCompositeLayout.java:583)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat org.appcelerator.titanium.view.TiCompositeLayout.onLayout(TiCompositeLayout.java:583)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.LinearLayout.setChildFrame(LinearLayout.java:1649)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.LinearLayout.layoutVertical(LinearLayout.java:1507)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.LinearLayout.onLayout(LinearLayout.java:1420)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1866)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1687)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4212)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.Choreographer$CallbackRecord.run(Choreographer.java:725)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.Choreographer.doCallbacks(Choreographer.java:555)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.Choreographer.doFrame(Choreographer.java:525)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.os.Handler.handleCallback(Handler.java:615)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.os.Handler.dispatchMessage(Handler.java:92)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.os.Looper.loop(Looper.java:137)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat android.app.ActivityThread.main(ActivityThread.java:4745)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat java.lang.reflect.Method.invokeNative(Native Method)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat java.lang.reflect.Method.invoke(Method.java:511)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)\r\n10-11 11:50:24.786: E/TiApplication(4067): \tat dalvik.system.NativeStart.main(Native Method)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): FATAL EXCEPTION: main\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): java.lang.NullPointerException\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.TiUITableView.registerForTouch(TiUITableView.java:214)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.handleGetView(TiViewProxy.java:446)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.getOrCreateView(TiViewProxy.java:415)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat org.appcelerator.titanium.proxy.TiViewProxy.forceCreateView(TiViewProxy.java:400)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.createControls(TiTableViewRowProxyItem.java:139)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.setRowData(TiTableViewRowProxyItem.java:286)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableViewRowProxyItem.setRowData(TiTableViewRowProxyItem.java:81)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableView$TTVListAdapter.getView(TiTableView.java:226)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.AbsListView.obtainView(AbsListView.java:2267)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.ListView.makeAndAddView(ListView.java:1769)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.ListView.fillDown(ListView.java:672)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.ListView.fillFromTop(ListView.java:733)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.ListView.layoutChildren(ListView.java:1622)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.AbsListView.onLayout(AbsListView.java:2102)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat ti.modules.titanium.ui.widget.tableview.TiTableView.onLayout(TiTableView.java:555)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat org.appcelerator.titanium.view.TiCompositeLayout.onLayout(TiCompositeLayout.java:583)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat org.appcelerator.titanium.view.TiCompositeLayout.onLayout(TiCompositeLayout.java:583)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.LinearLayout.setChildFrame(LinearLayout.java:1649)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.LinearLayout.layoutVertical(LinearLayout.java:1507)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.LinearLayout.onLayout(LinearLayout.java:1420)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.widget.FrameLayout.onLayout(FrameLayout.java:448)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.View.layout(View.java:13754)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewGroup.layout(ViewGroup.java:4362)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1866)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1687)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4212)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.Choreographer$CallbackRecord.run(Choreographer.java:725)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.Choreographer.doCallbacks(Choreographer.java:555)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.Choreographer.doFrame(Choreographer.java:525)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.os.Handler.handleCallback(Handler.java:615)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.os.Handler.dispatchMessage(Handler.java:92)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.os.Looper.loop(Looper.java:137)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat android.app.ActivityThread.main(ActivityThread.java:4745)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat java.lang.reflect.Method.invokeNative(Native Method)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat java.lang.reflect.Method.invoke(Method.java:511)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)\r\n10-11 11:50:24.872: E/AndroidRuntime(4067): \tat dalvik.system.NativeStart.main(Native Method)\r\n{code}\r\n\r\nSteps:\r\n1. Run the following code:\r\n{code}\r\nTitanium.UI.setBackgroundColor('#000');\r\n \r\nvar win2 = Titanium.UI.createWindow({\r\n backgroundColor : '#fff'\r\n});\r\n \r\nvar ds=[];\r\nvar ds1=[];\r\nvar row1 = Ti.UI.createTableViewRow();\r\nrow1.backgroundColor = 'yellow';\r\n \r\nvar label2 = Titanium.UI.createLabel({\r\n text : 'I am Row2',\r\n width : 'auto'\r\n});\r\nvar row2 = Ti.UI.createTableViewRow();\r\nrow2.add(label2);\r\nds1.push(row2);\r\nvar table1 = Ti.UI.createTableView({data:ds1,height:100});\r\nrow1.add(table1);\r\nds.push(row1);\r\nvar table = Ti.UI.createTableView({data:ds,height:200,top:20});\r\n \r\nwin2.add(table);\r\nlabel2.addEventListener('click', function(e) {\r\n \r\n var win = Ti.UI.createWindow({backgroundColor: 'black'});\r\n win.open({\r\n fullscreen:false\r\n });\r\n})\r\nwin2.open();\r\n{code}\r\n\r\nExpected:\r\nShould see a tableView with 2 rows\r\n\r\nActual:\r\nThe app crashes", "attachment": [], "flagged": false, "summary": "Android: TableViewRow - App crashes on launch", "creator": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "subtasks": [], "reporter": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "environment": "Tested on:\r\nOS: Mac OS X Lion 10.7.4\r\nTitanium Studio, build: 3.0.0.201210090117\r\nTitanium SDK, build: 3.0.0.v20121010184612\r\nDevice: Samsung Galaxy Nexus (4.1.1)", "comment": { "comments": [ { "id": "223217", "author": { "name": "krowley", "key": "krowley", "displayName": "Karl Rowley", "active": true, "timeZone": "America/Los_Angeles" }, "body": "This works with the fix for [TIMOB-11320]. I\"m going to close as a duplicate.", "updateAuthor": { "name": "krowley", "key": "krowley", "displayName": "Karl Rowley", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-11T23:25:23.000+0000", "updated": "2012-10-11T23:25:23.000+0000" }, { "id": "223218", "author": { "name": "krowley", "key": "krowley", "displayName": "Karl Rowley", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Duplicate of [TIMOB-11320]", "updateAuthor": { "name": "krowley", "key": "krowley", "displayName": "Karl Rowley", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-11T23:26:14.000+0000", "updated": "2012-10-11T23:26:14.000+0000" }, { "id": "224076", "author": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "body": "Closing as fixed. Verified and tested on:\r\nTitanium Studio, build: 3.0.0.201210151149\r\nTitanium SDK, build: 3.1.0.v20121017102121\r\nDevice: Nexus 7 (4.1.1)", "updateAuthor": { "name": "tsmolich", "key": "tsmolich", "displayName": "Tamila Smolich", "active": true, "timeZone": "America/Los_Angeles" }, "created": "2012-10-17T21:47:27.000+0000", "updated": "2012-10-17T21:47:27.000+0000" } ], "maxResults": 3, "total": 3, "startAt": 0 } } }