of12: simplify importing
diff --git a/src/python/of12/__init__.py b/src/python/of12/__init__.py
index e69de29..36dd8fa 100644
--- a/src/python/of12/__init__.py
+++ b/src/python/of12/__init__.py
@@ -0,0 +1,10 @@
+# Allow accessing constants through the top-level module
+from cstruct import *
+
+# Allow accessing submodules without additional imports
+import action
+import bucket
+import instruction
+import match
+import message
+import parse
diff --git a/tests-1.2/basic.py b/tests-1.2/basic.py
index 3a9c3d8..2fd7fb9 100644
--- a/tests-1.2/basic.py
+++ b/tests-1.2/basic.py
@@ -8,23 +8,13 @@
 
 import sys
 import logging
-
 import unittest
-
-import oftest.controller as controller
-import oftest.dataplane as dataplane
-import oftest.base_tests as base_tests
+import ipaddr
 
 from oftest import config
-import oftest.controller as controller
-import oftest.dataplane as dataplane
+import ofp
 import oftest.base_tests as base_tests
-import of12.cstruct as ofp
-import of12.message as message
-import of12.action as action
-
 import oftest.oft12.testutils as testutils
-import ipaddr
 
 class Echo(base_tests.SimpleProtocol):
     """
@@ -38,7 +28,7 @@
     Test echo response with short string data
     """
     def runTest(self):
-        request = message.echo_request()
+        request = ofp.message.echo_request()
         request.data = 'OpenFlow Will Rule The World'
         response, _ = self.controller.transact(request)
         self.assertEqual(response.header.type, ofp.OFPT_ECHO_REPLY,
@@ -55,7 +45,7 @@
     Does NOT test the contents; just that we get a response
     """
     def runTest(self):
-        request = message.features_request()
+        request = ofp.message.features_request()
         response,_ = self.controller.transact(request)
         self.assertTrue(response,"Got no features_reply to features_request")
         self.assertEqual(response.header.type, ofp.OFPT_FEATURES_REPLY,
@@ -118,10 +108,10 @@
         of_ports = config["port_map"].keys()
         of_ports.sort()
         for dp_port in of_ports:
-            msg = message.packet_out()
+            msg = ofp.message.packet_out()
             msg.in_port = ofp.OFPP_CONTROLLER
             msg.data = str(outpkt)
-            act = action.action_output()
+            act = ofp.action.action_output()
             act.port = dp_port
             self.assertTrue(msg.actions.add(act), 'Could not add action to msg')
 
@@ -150,7 +140,7 @@
     def runTest(self):
         logging.info("Running StatsGet")
         logging.info("Inserting trial flow")
-        request = message.flow_mod()
+        request = ofp.message.flow_mod()
         request.buffer_id = 0xffffffff
         for i in range(1,5):
             request.priority = i*1000
@@ -160,13 +150,13 @@
         logging.info("Removing all flows")
         testutils.delete_all_flows(self.controller, logging)
         logging.info("Sending flow request")
-        request = message.flow_stats_request()
+        request = ofp.message.flow_stats_request()
         request.out_port = ofp.OFPP_ANY
         request.out_group = ofp.OFPG_ANY
         request.table_id = 0xff
         response, _ = self.controller.transact(request, timeout=2)
         self.assertTrue(response is not None, "Did not get response")
-        self.assertTrue(isinstance(response,message.flow_stats_reply),"Not a flow_stats_reply")
+        self.assertTrue(isinstance(response,ofp.message.flow_stats_reply),"Not a flow_stats_reply")
         self.assertEqual(len(response.stats),0)
         logging.debug(response.show())
         
@@ -181,7 +171,7 @@
     def runTest(self):
         logging.info("Running StatsGet")
         logging.info("Inserting trial flow")
-        request = message.flow_mod()
+        request = ofp.message.flow_mod()
         request.buffer_id = 0xffffffff
         rv = self.controller.message_send(request)
         self.assertTrue(rv != -1, "Failed to insert test flow")
@@ -200,7 +190,7 @@
     def runTest(self):
         logging.info("Running TableStatsGet")
         logging.info("Sending table stats request")
-        request = message.table_stats_request()
+        request = ofp.message.table_stats_request()
         response, _ = self.controller.transact(request, timeout=2)
         self.assertTrue(response is not None, "Did not get response")
         logging.debug(response.show())
@@ -214,7 +204,7 @@
 
     def runTest(self):
         logging.info("Running " + str(self))
-        request = message.flow_mod()
+        request = ofp.message.flow_mod()
         request.buffer_id = 0xffffffff
         rv = self.controller.message_send(request)
         self.assertTrue(rv != -1, "Error installing flow mod")
@@ -267,7 +257,7 @@
     """        
     def runTest(self):
         logging.info("Running " + str(self))
-        table_mod = message.table_mod()
+        table_mod = ofp.message.table_mod()
         table_mod.table_id = 0 # first table should always exist
         table_mod.config = ofp.OFPTC_TABLE_MISS_CONTROLLER