Add Unit Tests for EasySetup APIs.
[platform/upstream/iotivity.git] / service / easy-setup / mediator / richsdk / SConscript
old mode 100644 (file)
new mode 100755 (executable)
index f631761..585b1ff
@@ -49,7 +49,7 @@ if target_enrollee == 'arduino':
 
 # Add third party libraries
 lib_env = env.Clone()
-SConscript(env.get('SRC_DIR') + '/service/third_party_libs.scons', 'lib_env')
+SConscript('#service/third_party_libs.scons', 'lib_env')
 
 easy_setup_env = lib_env.Clone()
 target_os = env.get('TARGET_OS')
@@ -59,11 +59,11 @@ target_os = env.get('TARGET_OS')
 ######################################################################
 easy_setup_env.AppendUnique(CPPPATH = ['inc', 'src', '../../inc'])
 
-if target_os not in ['windows', 'winrt']:
+if target_os not in ['windows']:
     easy_setup_env.AppendUnique(CXXFLAGS = ['-Wall', '-std=c++0x'])
 
-if target_os in ['linux']:
-   easy_setup_env.AppendUnique(LIBS = ['pthread', 'dl'])
+if target_os in ['linux','tizen']:
+   easy_setup_env.AppendUnique(LIBS = ['pthread', 'dl', 'coap'])
 
 if target_os in ['android']:
        easy_setup_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')])
@@ -77,67 +77,103 @@ if target_os in ['android']:
        if not env.get('RELEASE'):
                easy_setup_env.AppendUnique(LIBS = ['log'])
 
-if target_os in ['linux']:
+if target_os in ['linux', 'tizen']:
        easy_setup_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')])
        easy_setup_env.AppendUnique(RPATH = [env.get('BUILD_DIR')])
        easy_setup_env.AppendUnique(CXXFLAGS = ['-pthread'])
-       easy_setup_env.PrependUnique(LIBS = ['oc', 'octbstack', 'oc_logger', 'pthread', 'connectivity_abstraction'])
+       easy_setup_env.PrependUnique(LIBS = ['oc', 'octbstack', 'oc_logger', 'connectivity_abstraction'])
        if env.get('SECURED') == '1':
                easy_setup_env.AppendUnique(LIBS = ['ocpmapi', 'ocprovision'])
 
-if target_os in ['android','linux']:
+if target_os in ['android','linux','ios','tizen']:
        easy_setup_env.PrependUnique(CPPPATH = [
                env.get('SRC_DIR') + '/resource/c_common/oic_malloc/include',
                env.get('SRC_DIR') + '/resource/include',
                env.get('SRC_DIR') + '/resource/csdk/logger/include',
-               env.get('SRC_DIR') + '/resource/csdk/stack/include',
-               env.get('SRC_DIR') + '/resource/csdk/logger/include',
+               env.get('SRC_DIR') + '/resource/csdk/stack/include',
+               env.get('SRC_DIR') + '/resource/csdk/logger/include',
                env.get('SRC_DIR') + '/resource/csdk/security/include',
                env.get('SRC_DIR') + '/extlibs/cjson',
-               env.get('SRC_DIR') + '/extlibs/sqlite3',
-               env.get('SRC_DIR') + '/service/easy-setup/inc',
-               'inc'])
+               env.get('SRC_DIR') + '/service/easy-setup/inc'])
+       if target_os not in ['linux', 'tizen']:
+               easy_setup_env.PrependUnique(CPPPATH = [env.get('SRC_DIR') + '/extlibs/sqlite3'])
        if env.get('SECURED') == '1':
+               with_upstream_libcoap = easy_setup_env.get('WITH_UPSTREAM_LIBCOAP')
+               if with_upstream_libcoap == '1':
+                       # For bring up purposes only, we manually copy the forked version to where the unforked version is downloaded.
+                       easy_setup_env.AppendUnique(CPPPATH = ['#extlibs/libcoap/libcoap/include'])
+               else:
+                       # For bring up purposes only, the forked version will live here.
+                       easy_setup_env.AppendUnique(CPPPATH = [env.get('SRC_DIR') + '/resource/csdk/connectivity/lib/libcoap-4.1.1/include'])
                easy_setup_env.AppendUnique(CPPPATH = [
                        env.get('SRC_DIR') + '/resource/csdk/security/provisioning/include',
+                       env.get('SRC_DIR') + '/resource/csdk/security/include/internal',
                        env.get('SRC_DIR') + '/resource/csdk/connectivity/api/',
-                       env.get('SRC_DIR') + '/resource/csdk/security/provisioning/include/internal',
+                       env.get('SRC_DIR') + '/resource/csdk/security/provisioning/include/internal',
+                       env.get('SRC_DIR') + '/resource/csdk/security/provisioning/include/cloud',
                        env.get('SRC_DIR') + '/resource/csdk/security/provisioning/include/oxm'])
+               if env.get('WITH_TCP') == True:
+                       easy_setup_env.AppendUnique(LIBS = ['mbedtls', 'mbedx509', 'mbedcrypto'])
+
+if not env.get('RELEASE') and target_os not in ['ios']:
+    easy_setup_env.PrependUnique(LIBS = ['gcov'])
+    easy_setup_env.AppendUnique(CCFLAGS = ['--coverage'])
 
 ######################################################################
 # Source files and Targets
 ######################################################################
 
-
 print"easysetup_path %s" % easysetup_path
 
 es_src = None
 
-if target_os in ['android','linux']:
+if target_os in ['android','linux','ios','tizen']:
        if env.get('SECURED') == '1':
                env.AppendUnique(es_src = [os.path.join(easysetup_path, 'src/EnrolleeSecurity.cpp')])
 
        es_common_src = ['src/RemoteEnrollee.cpp',
-               'src/RemoteEnrolleeResource.cpp',
+               'src/EnrolleeResource.cpp',
+               'src/CloudResource.cpp',
                'src/EasySetup.cpp',
                'src/ESException.cpp']
 
        env.AppendUnique(es_src = es_common_src)
 
-       es_sdk_shared = easy_setup_env.SharedLibrary('ESMediatorRich', env.get('es_src'))
-       easy_setup_env.InstallTarget(es_sdk_shared, 'libESMediatorRich')
+       es_sdk_static = easy_setup_env.StaticLibrary('ESMediatorRich', env.get('es_src'))
+       easy_setup_env.InstallTarget(es_sdk_static, 'libESMediatorRich')
+       if target_os not in ['ios']:
+               es_sdk_shared = easy_setup_env.SharedLibrary('ESMediatorRich', env.get('es_src'))
+               easy_setup_env.UserInstallTargetLib(es_sdk_shared, 'libESMediatorRich')
+               easy_setup_env.AppendUnique(LINKFLAGS = ['-Wl,-soname,libESMediatorRich.so'])
+
+filenames = [ 'ESException.h', 'ESRichCommon.h', 'EasySetup.hpp', 'RemoteEnrollee.h' ]
+for filename in filenames:
+       easy_setup_env.UserInstallTargetHeader('inc/' + filename, "service/easy-setup", filename)
 
 print "Files path is %s" % env.get('es_src')
 
 ######################################################################
+# Generate RichSDK Mediator AAR
+################################################ ######################
+if target_os in ['android']:
+       SConscript('android/SConscript')
+
+######################################################################
 # Build RichSDK Mediator Sample App
 ################################################ ######################
-if target_os == 'linux':
-       SConscript('../../sampleapp/mediator/linux/richsdk_sample/SConscript')
+#if target_os in ['linux']:
+#    SConscript('../../sampleapp/mediator/linux/richsdk_sample/SConscript')
+#      SConscript('../../sampleapp/mediator/linux-samsung/richsdk_sample/SConscript')
+
+#if target_os in ['android']:
+#      SConscript('../../sampleapp/mediator/android/SConscript')
+#      SConscript('../../sampleapp/mediator/android-samsung/SConscript')
+
 
 ######################################################################
 #Build UnitTestcases for Mediator[RichSDK]
 ################################################ ######################
-if target_os == 'linux':
-    SConscript('unittests/SConscript')
+if env.get('SECURED') == '0':
+   if target_os == 'linux':
+       SConscript('unittests/SConscript')