Browse Source

dbo; tests

tags/v1.0.0
Robin Thoni 8 years ago
parent
commit
c935a8cbb9
23 changed files with 379 additions and 285 deletions
  1. 3
    4
      app/src/main/java/com/rthoni/stssaguenay/business/STSBusiness.java
  2. 1
    4
      app/src/main/java/com/rthoni/stssaguenay/business/UsersSettingsBusiness.java
  3. 4
    23
      app/src/main/java/com/rthoni/stssaguenay/dbo/RoutesDbo.java
  4. 4
    24
      app/src/main/java/com/rthoni/stssaguenay/dbo/SchedulesDbo.java
  5. 4
    32
      app/src/main/java/com/rthoni/stssaguenay/dbo/StopsDbo.java
  6. 0
    21
      app/src/main/java/com/rthoni/stssaguenay/dbo/UserDbo.java
  7. 0
    33
      app/src/main/java/com/rthoni/stssaguenay/dbo/UserFavouriteStopsDbo.java
  8. 1
    28
      app/src/main/java/com/rthoni/stssaguenay/dbo/UsersSettingsDbo.java
  9. 2
    3
      app/src/main/java/com/rthoni/stssaguenay/ui/activities/MainActivity.java
  10. 1
    1
      app/src/main/res/values/strings.xml
  11. 2
    0
      luticateutils/build.gradle
  12. 11
    18
      luticateutils/src/main/java/com/luticate/utils/dbo/LuBoolDbo.java
  13. 1
    18
      luticateutils/src/main/java/com/luticate/utils/dbo/LuDataAccessConfigDbo.java
  14. 8
    1
      luticateutils/src/main/java/com/luticate/utils/dbo/LuDbo.java
  15. 27
    0
      luticateutils/src/main/java/com/luticate/utils/dbo/LuDoubleDbo.java
  16. 12
    18
      luticateutils/src/main/java/com/luticate/utils/dbo/LuIntDbo.java
  17. 27
    0
      luticateutils/src/main/java/com/luticate/utils/dbo/LuLongDbo.java
  18. 16
    15
      luticateutils/src/main/java/com/luticate/utils/dbo/LuPaginatedDbo.java
  19. 12
    23
      luticateutils/src/main/java/com/luticate/utils/dbo/LuStringDbo.java
  20. 0
    14
      luticateutils/src/main/java/com/luticate/utils/dbo/LuVoidDbo.java
  21. 222
    0
      luticateutils/src/test/java/com/luticate/utils/BasicDboTest.java
  22. 10
    0
      luticateutils/src/test/java/com/luticate/utils/TestDbo.java
  23. 11
    5
      luticateutils/src/test/java/com/luticate/utils/TestDboTest.java

+ 3
- 4
app/src/main/java/com/rthoni/stssaguenay/business/STSBusiness.java View File

10
 import com.rthoni.stssaguenay.dbo.UsersSettingsDbo;
10
 import com.rthoni.stssaguenay.dbo.UsersSettingsDbo;
11
 
11
 
12
 import org.json.JSONArray;
12
 import org.json.JSONArray;
13
-import org.json.JSONException;
14
 import org.json.JSONObject;
13
 import org.json.JSONObject;
15
 
14
 
16
 import java.util.List;
15
 import java.util.List;
29
             _config = new LuDataAccessConfigDbo();
28
             _config = new LuDataAccessConfigDbo();
30
             try {
29
             try {
31
                 String str = ctx.getString(R.string.luticate_config);
30
                 String str = ctx.getString(R.string.luticate_config);
32
-                _config.fromJson(new JSONObject(str));
33
-            } catch (JSONException e) {
31
+                _config.fromJson(str);
32
+            } catch (Exception e) {
34
                 e.printStackTrace();
33
                 e.printStackTrace();
35
                 _config = null;
34
                 _config = null;
36
                 return null;
35
                 return null;
73
         if (str != null) {
72
         if (str != null) {
74
             UserDbo user = new UserDbo();
73
             UserDbo user = new UserDbo();
75
             try {
74
             try {
76
-                user.fromString(str);
75
+                user.fromJson(str);
77
                 return user;
76
                 return user;
78
             } catch (Exception e) {
77
             } catch (Exception e) {
79
                 e.printStackTrace();
78
                 e.printStackTrace();

+ 1
- 4
app/src/main/java/com/rthoni/stssaguenay/business/UsersSettingsBusiness.java View File

6
 import com.rthoni.stssaguenay.dataaccess.UsersSettingsDataAccess;
6
 import com.rthoni.stssaguenay.dataaccess.UsersSettingsDataAccess;
7
 import com.rthoni.stssaguenay.dbo.UsersSettingsDbo;
7
 import com.rthoni.stssaguenay.dbo.UsersSettingsDbo;
8
 
8
 
9
-import org.json.JSONException;
10
-import org.json.JSONObject;
11
-
12
 /**
9
 /**
13
  * Created by robin on 10/3/16.
10
  * Created by robin on 10/3/16.
14
  */
11
  */
29
 
26
 
30
         UsersSettingsDbo settings = new UsersSettingsDbo();
27
         UsersSettingsDbo settings = new UsersSettingsDbo();
31
         try {
28
         try {
32
-            settings.fromString(data);
29
+            settings.fromJson(data);
33
         } catch (Exception e) {
30
         } catch (Exception e) {
34
             e.printStackTrace();
31
             e.printStackTrace();
35
             return null;
32
             return null;

+ 4
- 23
app/src/main/java/com/rthoni/stssaguenay/dbo/RoutesDbo.java View File

3
 import com.luticate.utils.dbo.LuDbo;
3
 import com.luticate.utils.dbo.LuDbo;
4
 import com.luticate.utils.dbo.LuPaginatedDbo;
4
 import com.luticate.utils.dbo.LuPaginatedDbo;
5
 
5
 
6
-import org.json.JSONException;
7
-import org.json.JSONObject;
8
-
9
-import java.util.HashMap;
10
-
11
 /**
6
 /**
12
  * Created by robin on 9/30/16.
7
  * Created by robin on 9/30/16.
13
  */
8
  */
16
 
11
 
17
     public static class PaginatedRoutesDbo extends LuPaginatedDbo<RoutesDbo>
12
     public static class PaginatedRoutesDbo extends LuPaginatedDbo<RoutesDbo>
18
     {
13
     {
14
+        public PaginatedRoutesDbo()
15
+        {
16
+            super(RoutesDbo.class);
17
+        }
19
     }
18
     }
20
 
19
 
21
     protected String _id;
20
     protected String _id;
26
 
25
 
27
     protected String _fgColor;
26
     protected String _fgColor;
28
 
27
 
29
-//    @Override
30
-//    public void fromJson(JSONObject json) throws JSONException {
31
-//        _id = json.getString("id");
32
-//        _name = json.getString("name");
33
-//        _bgColor = json.getString("bgColor");
34
-//        _fgColor = json.getString("fgColor");
35
-//    }
36
-//
37
-//    @Override
38
-//    public HashMap<String, Object> toArray() {
39
-//        HashMap<String, Object> map = new HashMap<>();
40
-//        map.put("id", _id);
41
-//        map.put("name", _name);
42
-//        map.put("bgColor", _bgColor);
43
-//        map.put("fgColor", _fgColor);
44
-//        return map;
45
-//    }
46
-
47
     public String getId() {
28
     public String getId() {
48
         return _id;
29
         return _id;
49
     }
30
     }

+ 4
- 24
app/src/main/java/com/rthoni/stssaguenay/dbo/SchedulesDbo.java View File

4
 import com.luticate.utils.dbo.LuPaginatedDbo;
4
 import com.luticate.utils.dbo.LuPaginatedDbo;
5
 
5
 
6
 import org.joda.time.LocalDateTime;
6
 import org.joda.time.LocalDateTime;
7
-import org.joda.time.LocalTime;
8
-import org.joda.time.format.DateTimeFormat;
9
-import org.joda.time.format.DateTimeFormatter;
10
-import org.json.JSONArray;
11
-import org.json.JSONException;
12
-import org.json.JSONObject;
13
 
7
 
14
-import java.util.HashMap;
15
 import java.util.List;
8
 import java.util.List;
16
-import java.util.Vector;
17
 
9
 
18
 /**
10
 /**
19
  * Created by robin on 10/1/16.
11
  * Created by robin on 10/1/16.
23
 
15
 
24
     public static class SchedulesDboArray extends LuPaginatedDbo<SchedulesDbo>
16
     public static class SchedulesDboArray extends LuPaginatedDbo<SchedulesDbo>
25
     {
17
     {
18
+        public SchedulesDboArray()
19
+        {
20
+            super(SchedulesDbo.class);
21
+        }
26
     }
22
     }
27
 
23
 
28
     protected String _stopId;
24
     protected String _stopId;
31
 
27
 
32
     protected List<LocalDateTime> _schedules;
28
     protected List<LocalDateTime> _schedules;
33
 
29
 
34
-//    @Override
35
-//    public void fromJson(JSONObject json) throws JSONException {
36
-//        _stopId = json.getString("stopId");
37
-//        _routeId = json.getString("routeId");
38
-//        _schedules = new Vector<>();
39
-//        JSONArray schedules = json.getJSONArray("schedules");
40
-//        for (int i = 0; i < schedules.length(); ++i) {
41
-//            _schedules.add(LocalDateTime.parse(schedules.getString(i), DateTimeFormat.forPattern("y-M-d H:m:s")));
42
-//        }
43
-//    }
44
-//
45
-//    @Override
46
-//    public HashMap<String, Object> toArray() {
47
-//        return null;
48
-//    }
49
-
50
     public String getStopId() {
30
     public String getStopId() {
51
         return _stopId;
31
         return _stopId;
52
     }
32
     }

+ 4
- 32
app/src/main/java/com/rthoni/stssaguenay/dbo/StopsDbo.java View File

1
 package com.rthoni.stssaguenay.dbo;
1
 package com.rthoni.stssaguenay.dbo;
2
 
2
 
3
-import android.util.Pair;
4
-
5
 import com.luticate.utils.dbo.LuDbo;
3
 import com.luticate.utils.dbo.LuDbo;
6
 import com.luticate.utils.dbo.LuPaginatedDbo;
4
 import com.luticate.utils.dbo.LuPaginatedDbo;
7
 
5
 
8
-import org.json.JSONArray;
9
-import org.json.JSONException;
10
-import org.json.JSONObject;
11
-
12
-import java.util.HashMap;
13
 import java.util.List;
6
 import java.util.List;
14
-import java.util.Vector;
15
 
7
 
16
 /**
8
 /**
17
  * Created by robin on 9/29/16.
9
  * Created by robin on 9/29/16.
20
 
12
 
21
     public static class PaginatedStopsDbo extends LuPaginatedDbo<StopsDbo>
13
     public static class PaginatedStopsDbo extends LuPaginatedDbo<StopsDbo>
22
     {
14
     {
15
+        public PaginatedStopsDbo()
16
+        {
17
+            super(StopsDbo.class);
18
+        }
23
     }
19
     }
24
 
20
 
25
-//    @Override
26
-//    public void fromJson(JSONObject json) throws JSONException {
27
-//        _name = json.getString("name");
28
-//        _routes = new Vector<>();
29
-//        JSONArray routes = json.getJSONArray("routes");
30
-//        for (int i = 0; i < routes.length(); ++i) {
31
-//            _routes.add(routes.getString(i));
32
-//        }
33
-//        _id = json.getString("id");
34
-//        _posX = json.getDouble("posX");
35
-//        _posY = json.getDouble("posY");
36
-//    }
37
-//
38
-//    @Override
39
-//    public HashMap<String, Object> toArray() {
40
-//        HashMap<String, Object> map = new HashMap<>();
41
-//        map.put("name", _name);
42
-//        map.put("routes", _routes);
43
-//        map.put("id", _id);
44
-//        map.put("posX", _posX);
45
-//        map.put("posY", _posY);
46
-//        return map;
47
-//    }
48
-
49
     protected String _name;
21
     protected String _name;
50
 
22
 
51
     protected List<String> _routes;
23
     protected List<String> _routes;

+ 0
- 21
app/src/main/java/com/rthoni/stssaguenay/dbo/UserDbo.java View File

2
 
2
 
3
 import com.luticate.utils.dbo.LuDbo;
3
 import com.luticate.utils.dbo.LuDbo;
4
 
4
 
5
-import org.json.JSONException;
6
-import org.json.JSONObject;
7
-
8
-import java.util.HashMap;
9
-
10
 /**
5
 /**
11
  * Created by robin on 10/3/16.
6
  * Created by robin on 10/3/16.
12
  */
7
  */
19
 
14
 
20
     protected String _email;
15
     protected String _email;
21
 
16
 
22
-//    @Override
23
-//    public void fromJson(JSONObject json) throws JSONException {
24
-//        _id = json.getString("id");
25
-//        _name = json.getString("name");
26
-//        _email = json.getString("email");
27
-//    }
28
-//
29
-//    @Override
30
-//    public HashMap<String, Object> toArray() {
31
-//        HashMap<String, Object> map = new HashMap<>();
32
-//        map.put("id", _id);
33
-//        map.put("name", _name);
34
-//        map.put("email", _email);
35
-//        return map;
36
-//    }
37
-
38
     public String getId() {
17
     public String getId() {
39
         return _id;
18
         return _id;
40
     }
19
     }

+ 0
- 33
app/src/main/java/com/rthoni/stssaguenay/dbo/UserFavouriteStopsDbo.java View File

2
 
2
 
3
 import com.luticate.utils.dbo.LuDbo;
3
 import com.luticate.utils.dbo.LuDbo;
4
 
4
 
5
-import org.json.JSONArray;
6
-import org.json.JSONException;
7
-import org.json.JSONObject;
8
-
9
-import java.util.HashMap;
10
 import java.util.List;
5
 import java.util.List;
11
-import java.util.Vector;
12
 
6
 
13
 /**
7
 /**
14
  * Created by robin on 10/1/16.
8
  * Created by robin on 10/1/16.
22
 
16
 
23
     protected String _name;
17
     protected String _name;
24
 
18
 
25
-//    @Override
26
-//    public void fromJson(JSONObject json) throws JSONException {
27
-//        _stop = new StopsDbo();
28
-//        _stop.fromJson(json.getJSONObject("stop"));
29
-//        _routes = new Vector<>();
30
-//        JSONArray routes = json.getJSONArray("routes");
31
-//        for (int i = 0; i < routes.length(); ++i) {
32
-//            RoutesDbo route = new RoutesDbo();
33
-//            route.fromJson(routes.getJSONObject(i));
34
-//            _routes.add(route);
35
-//        }
36
-//        _name = json.getString("name");
37
-//    }
38
-//
39
-//    @Override
40
-//    public HashMap<String, Object> toArray() {
41
-//        HashMap<String, Object> map = new HashMap<>();
42
-//        map.put("stop", _stop.toArray());
43
-//        List<Object> routes = new Vector<>();
44
-//        for (RoutesDbo route : _routes) {
45
-//            routes.add(route.toArray());
46
-//        }
47
-//        map.put("routes", routes);
48
-//        map.put("name", _name);
49
-//        return map;
50
-//    }
51
-
52
     public StopsDbo getStop() {
19
     public StopsDbo getStop() {
53
         return _stop;
20
         return _stop;
54
     }
21
     }

+ 1
- 28
app/src/main/java/com/rthoni/stssaguenay/dbo/UsersSettingsDbo.java View File

2
 
2
 
3
 import com.luticate.utils.dbo.LuDbo;
3
 import com.luticate.utils.dbo.LuDbo;
4
 
4
 
5
-import org.json.JSONArray;
6
-import org.json.JSONException;
7
-import org.json.JSONObject;
8
-
9
-import java.util.HashMap;
10
 import java.util.List;
5
 import java.util.List;
11
-import java.util.Vector;
12
 
6
 
13
 /**
7
 /**
14
  * Created by robin on 10/3/16.
8
  * Created by robin on 10/3/16.
15
  */
9
  */
16
 
10
 
17
 public class UsersSettingsDbo extends LuDbo {
11
 public class UsersSettingsDbo extends LuDbo {
18
-    protected List<UserFavouriteStopsDbo> _favouriteStops;
19
 
12
 
20
-//    @Override
21
-//    public void fromJson(JSONObject json) throws JSONException {
22
-//        _favouriteStops = new Vector<>();
23
-//        JSONArray stops = json.getJSONArray("favouriteStops");
24
-//        for (int i = 0; i < stops.length(); ++i) {
25
-//            UserFavouriteStopsDbo stop = new UserFavouriteStopsDbo();
26
-//            stop.fromJson(stops.getJSONObject(i));
27
-//            _favouriteStops.add(stop);
28
-//        }
29
-//    }
30
-//
31
-//    @Override
32
-//    public HashMap<String, Object> toArray() {
33
-//        HashMap<String, Object> map = new HashMap<>();
34
-//        List<HashMap<String, Object>> stops = new Vector<>();
35
-//        for (UserFavouriteStopsDbo stop : _favouriteStops) {
36
-//            stops.add(stop.toArray());
37
-//        }
38
-//        map.put("favouriteStops", stops);
39
-//        return map;
40
-//    }
13
+    protected List<UserFavouriteStopsDbo> _favouriteStops;
41
 
14
 
42
     public List<UserFavouriteStopsDbo> getFavouriteStops() {
15
     public List<UserFavouriteStopsDbo> getFavouriteStops() {
43
         return _favouriteStops;
16
         return _favouriteStops;

+ 2
- 3
app/src/main/java/com/rthoni/stssaguenay/ui/activities/MainActivity.java View File

48
 import com.rthoni.stssaguenay.ui.fragments.HomeFragment;
48
 import com.rthoni.stssaguenay.ui.fragments.HomeFragment;
49
 import com.rthoni.stssaguenay.ui.fragments.StopViewerFragment;
49
 import com.rthoni.stssaguenay.ui.fragments.StopViewerFragment;
50
 
50
 
51
-import org.json.JSONException;
52
 import org.json.JSONObject;
51
 import org.json.JSONObject;
53
 
52
 
54
 import java.util.List;
53
 import java.util.List;
279
         if (requestCode == ADD_FAVOURITE_STOP_REQUEST_CODE && resultCode == RESULT_OK) {
278
         if (requestCode == ADD_FAVOURITE_STOP_REQUEST_CODE && resultCode == RESULT_OK) {
280
             UserFavouriteStopsDbo favouriteStopDbo = new UserFavouriteStopsDbo();
279
             UserFavouriteStopsDbo favouriteStopDbo = new UserFavouriteStopsDbo();
281
             try {
280
             try {
282
-                favouriteStopDbo.fromString(data.getStringExtra(StopPickerActivity.FAVOURITE_STOP_EXTRA_NAME));
281
+                favouriteStopDbo.fromJson(data.getStringExtra(StopPickerActivity.FAVOURITE_STOP_EXTRA_NAME));
283
             } catch (Exception e) {
282
             } catch (Exception e) {
284
                 e.printStackTrace();
283
                 e.printStackTrace();
285
                 return;
284
                 return;
297
         else if (requestCode == SEARCH_STOP_REQUEST_CODE && resultCode == RESULT_OK) {
296
         else if (requestCode == SEARCH_STOP_REQUEST_CODE && resultCode == RESULT_OK) {
298
             final StopsDbo stopDbo = new StopsDbo();
297
             final StopsDbo stopDbo = new StopsDbo();
299
             try {
298
             try {
300
-                stopDbo.fromString(data.getStringExtra(StopPickerActivity.STOP_EXTRA_NAME));
299
+                stopDbo.fromJson(data.getStringExtra(StopPickerActivity.STOP_EXTRA_NAME));
301
             } catch (Exception e) {
300
             } catch (Exception e) {
302
                 e.printStackTrace();
301
                 e.printStackTrace();
303
                 return;
302
                 return;

+ 1
- 1
app/src/main/res/values/strings.xml View File

4
     <string name="ad_init">ca-app-pub-2016581167110949~3084832113</string>
4
     <string name="ad_init">ca-app-pub-2016581167110949~3084832113</string>
5
     <string name="facebook_app_id">1463583156990249</string>
5
     <string name="facebook_app_id">1463583156990249</string>
6
     <string name="map_api_key">AIzaSyD4FmpkQmk2t61Lx9spzpTx2CAy2CmijX0</string>
6
     <string name="map_api_key">AIzaSyD4FmpkQmk2t61Lx9spzpTx2CAy2CmijX0</string>
7
-    <string name="luticate_config">{\"baseURL\": \"https://sts.rthoni.com/api/v1/\"}</string>
7
+    <string name="luticate_config">{\"baseUrl\": \"https://sts.rthoni.com/api/v1/\"}</string>
8
 
8
 
9
 
9
 
10
     <string name="navigation_drawer_open">Open navigation drawer</string>
10
     <string name="navigation_drawer_open">Open navigation drawer</string>

+ 2
- 0
luticateutils/build.gradle View File

24
     downloadFrom 'https://oss.sonatype.org/content/groups/public/org/robolectric/android-all/4.3_r2-robolectric-0/android-all-4.3_r2-robolectric-0.jar'
24
     downloadFrom 'https://oss.sonatype.org/content/groups/public/org/robolectric/android-all/4.3_r2-robolectric-0/android-all-4.3_r2-robolectric-0.jar'
25
 
25
 
26
     keepStartingWith "org.json."
26
     keepStartingWith "org.json."
27
+
28
+    keep "android.util.Base64"
27
 }
29
 }
28
 
30
 
29
 dependencies {
31
 dependencies {

+ 11
- 18
luticateutils/src/main/java/com/luticate/utils/dbo/LuBoolDbo.java View File

1
 package com.luticate.utils.dbo;
1
 package com.luticate.utils.dbo;
2
 
2
 
3
-import org.json.JSONException;
4
-import org.json.JSONObject;
5
-
6
-import java.util.HashMap;
7
-
8
 /**
3
 /**
9
  * Created by robin on 11/27/15.
4
  * Created by robin on 11/27/15.
10
  */
5
  */
11
 public class LuBoolDbo extends LuDbo {
6
 public class LuBoolDbo extends LuDbo {
12
-    public boolean isValue() {
13
-        return _value;
7
+
8
+    private Boolean _value;
9
+
10
+    public LuBoolDbo()
11
+    {
14
     }
12
     }
15
 
13
 
16
-    public void setValue(boolean value) {
14
+    public LuBoolDbo(Boolean value)
15
+    {
17
         _value = value;
16
         _value = value;
18
     }
17
     }
19
 
18
 
20
-    private boolean _value;
21
-
22
-    @Override
23
-    public void fromJson(JSONObject json) throws JSONException {
24
-        _value = json.getBoolean("value");
19
+    public Boolean getBool() {
20
+        return _value;
25
     }
21
     }
26
 
22
 
27
-    @Override
28
-    public HashMap<String, Object> toArray() {
29
-        HashMap<String, Object> array = new HashMap<>();
30
-        array.put("value", _value);
31
-        return array;
23
+    public void setBool(Boolean value) {
24
+        _value = value;
32
     }
25
     }
33
 }
26
 }

+ 1
- 18
luticateutils/src/main/java/com/luticate/utils/dbo/LuDataAccessConfigDbo.java View File

49
         Map<String, String> map = new HashMap<>();
49
         Map<String, String> map = new HashMap<>();
50
         if (_httpUsername != null) {
50
         if (_httpUsername != null) {
51
             map.put("Authorization", "Basic " + Base64.encodeToString(
51
             map.put("Authorization", "Basic " + Base64.encodeToString(
52
-                    String.format("%s:%s", _httpUsername, _httpPassword).getBytes(), Base64.DEFAULT));
52
+                    String.format("%s:%s", _httpUsername, _httpPassword).getBytes(), Base64.NO_WRAP));
53
         }
53
         }
54
         return map;
54
         return map;
55
     }
55
     }
56
 
56
 
57
-    @Override
58
-    public void fromJson(JSONObject json) throws JSONException {
59
-        _baseUrl = json.getString("baseURL");
60
-        if (!json.isNull("httpUsername")) {
61
-            _httpUsername = json.getString("httpUsername");
62
-            _httpPassword = json.getString("httpPassword");
63
-        }
64
-        else {
65
-            _httpUsername = null;
66
-            _httpPassword = null;
67
-        }
68
-    }
69
-
70
-    @Override
71
-    public HashMap<String, Object> toArray() {
72
-        return null;
73
-    }
74
 }
57
 }

+ 8
- 1
luticateutils/src/main/java/com/luticate/utils/dbo/LuDbo.java View File

14
 
14
 
15
 import java.lang.reflect.Array;
15
 import java.lang.reflect.Array;
16
 import java.lang.reflect.Field;
16
 import java.lang.reflect.Field;
17
+import java.lang.reflect.Modifier;
17
 import java.lang.reflect.ParameterizedType;
18
 import java.lang.reflect.ParameterizedType;
18
 import java.util.AbstractMap;
19
 import java.util.AbstractMap;
19
 import java.util.HashMap;
20
 import java.util.HashMap;
171
         return obj == null ? null : obj.getClass();
172
         return obj == null ? null : obj.getClass();
172
     }
173
     }
173
 
174
 
174
-    public void fromString(String data) throws Exception
175
+    public void fromJson(String data) throws Exception
175
     {
176
     {
176
         JSONObject json = new JSONObject(data);
177
         JSONObject json = new JSONObject(data);
177
         fromJson(json);
178
         fromJson(json);
180
     public void fromJson(JSONObject json) throws Exception
181
     public void fromJson(JSONObject json) throws Exception
181
     {
182
     {
182
         for (Field field : getClass().getDeclaredFields()) {
183
         for (Field field : getClass().getDeclaredFields()) {
184
+            if (Modifier.isTransient(field.getModifiers())) {
185
+                continue;
186
+            }
183
             String key = getJsonFromField(field.getName());
187
             String key = getJsonFromField(field.getName());
184
             Class clazz = field.getType();
188
             Class clazz = field.getType();
185
             if (json.has(key)) {
189
             if (json.has(key)) {
234
         HashMap<String, Object> map = new HashMap<>();
238
         HashMap<String, Object> map = new HashMap<>();
235
 
239
 
236
         for (Field field : getClass().getDeclaredFields()) {
240
         for (Field field : getClass().getDeclaredFields()) {
241
+            if (Modifier.isTransient(field.getModifiers())) {
242
+                continue;
243
+            }
237
             String key = getJsonFromField(field.getName());
244
             String key = getJsonFromField(field.getName());
238
             Class clazz = field.getType();
245
             Class clazz = field.getType();
239
             field.setAccessible(true);
246
             field.setAccessible(true);

+ 27
- 0
luticateutils/src/main/java/com/luticate/utils/dbo/LuDoubleDbo.java View File

1
+package com.luticate.utils.dbo;
2
+
3
+/**
4
+ * Created by robin on 10/22/16.
5
+ */
6
+
7
+public class LuDoubleDbo extends LuDbo {
8
+
9
+    protected Double _value;
10
+
11
+    public LuDoubleDbo()
12
+    {
13
+    }
14
+
15
+    public LuDoubleDbo(Double value)
16
+    {
17
+        _value = value;
18
+    }
19
+
20
+    public Double getDouble() {
21
+        return _value;
22
+    }
23
+
24
+    public void setDouble(Double aDouble) {
25
+        _value = aDouble;
26
+    }
27
+}

+ 12
- 18
luticateutils/src/main/java/com/luticate/utils/dbo/LuIntDbo.java View File

1
 package com.luticate.utils.dbo;
1
 package com.luticate.utils.dbo;
2
 
2
 
3
-import org.json.JSONException;
4
-import org.json.JSONObject;
5
-
6
-import java.util.HashMap;
7
-
8
 /**
3
 /**
9
  * Created by robin on 11/27/15.
4
  * Created by robin on 11/27/15.
10
  */
5
  */
11
 public class LuIntDbo extends LuDbo {
6
 public class LuIntDbo extends LuDbo {
12
-    public int getInt() {
13
-        return _value;
7
+
8
+    private Integer _value;
9
+
10
+    public LuIntDbo()
11
+    {
14
     }
12
     }
15
 
13
 
16
-    public void setInt(int value) {
14
+    public LuIntDbo(Integer value)
15
+    {
17
         _value = value;
16
         _value = value;
18
     }
17
     }
19
 
18
 
20
-    private int _value;
21
-
22
-    @Override
23
-    public void fromJson(JSONObject json) throws JSONException {
24
-        _value = json.getInt("value");
19
+    public Integer getInt() {
20
+        return _value;
25
     }
21
     }
26
 
22
 
27
-    @Override
28
-    public HashMap<String, Object> toArray() {
29
-        HashMap<String, Object> array = new HashMap<>();
30
-        array.put("value", _value);
31
-        return array;
23
+    public void setInt(Integer value) {
24
+        _value = value;
32
     }
25
     }
26
+
33
 }
27
 }

+ 27
- 0
luticateutils/src/main/java/com/luticate/utils/dbo/LuLongDbo.java View File

1
+package com.luticate.utils.dbo;
2
+
3
+/**
4
+ * Created by robin on 10/22/16.
5
+ */
6
+
7
+public class LuLongDbo extends LuDbo {
8
+
9
+    protected Long _value;
10
+
11
+    public LuLongDbo()
12
+    {
13
+    }
14
+
15
+    public LuLongDbo(Long value)
16
+    {
17
+        _value = value;
18
+    }
19
+
20
+    public Long getLong() {
21
+        return _value;
22
+    }
23
+
24
+    public void setLong(Long aLong) {
25
+        _value = aLong;
26
+    }
27
+}

+ 16
- 15
luticateutils/src/main/java/com/luticate/utils/dbo/LuPaginatedDbo.java View File

1
 package com.luticate.utils.dbo;
1
 package com.luticate.utils.dbo;
2
 
2
 
3
 import org.json.JSONArray;
3
 import org.json.JSONArray;
4
-import org.json.JSONException;
5
 import org.json.JSONObject;
4
 import org.json.JSONObject;
6
 
5
 
7
-import java.lang.reflect.ParameterizedType;
8
 import java.util.HashMap;
6
 import java.util.HashMap;
9
 import java.util.List;
7
 import java.util.List;
10
 import java.util.Vector;
8
 import java.util.Vector;
15
  */
13
  */
16
 public class LuPaginatedDbo<T extends LuDbo> extends LuDbo {
14
 public class LuPaginatedDbo<T extends LuDbo> extends LuDbo {
17
 
15
 
16
+    private transient Class<T> _clazz;
17
+
18
+    private List<T> _data = new Vector<>();
19
+
20
+    private int _count;
21
+
22
+    public LuPaginatedDbo(Class<T> clazz)
23
+    {
24
+        _clazz = clazz;
25
+    }
26
+
18
     public List<T> getData() {
27
     public List<T> getData() {
19
         return _data;
28
         return _data;
20
     }
29
     }
31
         _count = count;
40
         _count = count;
32
     }
41
     }
33
 
42
 
34
-    private List<T> _data = new Vector<>();
35
-
36
-    private int _count;
37
-
38
     @Override
43
     @Override
39
-    public void fromJson(JSONObject json) throws JSONException {
44
+    public void fromJson(JSONObject json) throws Exception {
40
         _count = json.getInt("count");
45
         _count = json.getInt("count");
41
         JSONArray array = json.getJSONArray("data");
46
         JSONArray array = json.getJSONArray("data");
47
+
42
         for (int i = 0; i < array.length(); ++i) {
48
         for (int i = 0; i < array.length(); ++i) {
43
-            try {
44
-                T dbo = (T)((Class)((ParameterizedType)this.getClass().
45
-                        getGenericSuperclass()).getActualTypeArguments()[0]).newInstance();
46
-                dbo.fromJson(array.getJSONObject(i));
47
-                _data.add(dbo);
48
-            } catch (Exception e) {
49
-                e.printStackTrace();
50
-            }
49
+            T dbo = _clazz.newInstance();
50
+            dbo.fromJson(array.getJSONObject(i));
51
+            _data.add(dbo);
51
         }
52
         }
52
     }
53
     }
53
 
54
 

+ 12
- 23
luticateutils/src/main/java/com/luticate/utils/dbo/LuStringDbo.java View File

1
 package com.luticate.utils.dbo;
1
 package com.luticate.utils.dbo;
2
 
2
 
3
-import org.json.JSONException;
4
-import org.json.JSONObject;
5
-
6
-import java.util.HashMap;
7
-
8
 /**
3
 /**
9
  * Created by robin on 11/27/15.
4
  * Created by robin on 11/27/15.
10
  */
5
  */
11
 public class LuStringDbo extends LuDbo {
6
 public class LuStringDbo extends LuDbo {
12
-    public String getString() {
13
-        return _value;
7
+
8
+    private String _value;
9
+
10
+    public LuStringDbo()
11
+    {
14
     }
12
     }
15
 
13
 
16
-    public void setString(String value) {
14
+    public LuStringDbo(String value)
15
+    {
17
         _value = value;
16
         _value = value;
18
     }
17
     }
19
 
18
 
20
-    private String _value;
21
-
22
-    @Override
23
-    public void fromJson(JSONObject json) throws JSONException {
24
-        if (json.isNull("value")) {
25
-            _value = null;
26
-        }
27
-        else {
28
-            _value = json.getString("value");
29
-        }
19
+    public String getString() {
20
+        return _value;
30
     }
21
     }
31
 
22
 
32
-    @Override
33
-    public HashMap<String, Object> toArray() {
34
-        HashMap<String, Object> array = new HashMap<>();
35
-        array.put("value", _value);
36
-        return array;
23
+    public void setString(String value) {
24
+        _value = value;
37
     }
25
     }
26
+
38
 }
27
 }

+ 0
- 14
luticateutils/src/main/java/com/luticate/utils/dbo/LuVoidDbo.java View File

1
 package com.luticate.utils.dbo;
1
 package com.luticate.utils.dbo;
2
 
2
 
3
-import org.json.JSONException;
4
-import org.json.JSONObject;
5
-
6
-import java.util.HashMap;
7
-
8
 /**
3
 /**
9
  * Created by robin on 11/27/15.
4
  * Created by robin on 11/27/15.
10
  */
5
  */
11
 public class LuVoidDbo extends LuDbo {
6
 public class LuVoidDbo extends LuDbo {
12
-    @Override
13
-    public void fromJson(JSONObject json) throws JSONException {
14
-
15
-    }
16
-
17
-    @Override
18
-    public HashMap<String, Object> toArray() {
19
-        return null;
20
-    }
21
 }
7
 }

+ 222
- 0
luticateutils/src/test/java/com/luticate/utils/BasicDboTest.java View File

1
+package com.luticate.utils;
2
+
3
+import com.luticate.utils.dbo.LuBoolDbo;
4
+import com.luticate.utils.dbo.LuDataAccessConfigDbo;
5
+import com.luticate.utils.dbo.LuDoubleDbo;
6
+import com.luticate.utils.dbo.LuIntDbo;
7
+import com.luticate.utils.dbo.LuLongDbo;
8
+import com.luticate.utils.dbo.LuPaginatedDbo;
9
+import com.luticate.utils.dbo.LuStringDbo;
10
+import com.luticate.utils.dbo.LuVoidDbo;
11
+
12
+import org.junit.Test;
13
+
14
+import java.util.HashMap;
15
+import java.util.List;
16
+import java.util.Map;
17
+import java.util.Vector;
18
+
19
+import static org.junit.Assert.*;
20
+
21
+/**
22
+ * Created by robin on 10/22/16.
23
+ */
24
+
25
+public class BasicDboTest {
26
+
27
+    @Test
28
+    public void boolTest() throws Exception {
29
+        LuBoolDbo dbo = new LuBoolDbo();
30
+        dbo.fromJson("{\"value\": true}");
31
+        assertTrue(dbo.getBool());
32
+
33
+        dbo = new LuBoolDbo();
34
+        dbo.fromJson("{\"value\": null}");
35
+        assertNull(dbo.getBool());
36
+
37
+        dbo = new LuBoolDbo();
38
+        dbo.fromJson("{\"value\": false}");
39
+        assertFalse(dbo.getBool());
40
+        dbo.setBool(true);
41
+
42
+        LuBoolDbo dbo2 = new LuBoolDbo();
43
+        dbo2.fromJson(dbo.toString());
44
+        assertTrue(dbo2.getBool());
45
+
46
+        dbo = new LuBoolDbo(false);
47
+        assertFalse(dbo.getBool());
48
+
49
+        dbo = new LuBoolDbo(true);
50
+        assertTrue(dbo.getBool());
51
+    }
52
+
53
+    @Test
54
+    public void intTest() throws Exception {
55
+        LuIntDbo dbo = new LuIntDbo();
56
+        dbo.fromJson("{\"value\": 42}");
57
+        assertEquals(42, dbo.getInt().intValue());
58
+
59
+        dbo = new LuIntDbo();
60
+        dbo.fromJson("{\"value\": null}");
61
+        assertNull(dbo.getInt());
62
+
63
+        dbo = new LuIntDbo();
64
+        dbo.fromJson("{\"value\": 24}");
65
+        assertEquals(24, dbo.getInt().intValue());
66
+        dbo.setInt(4242);
67
+
68
+        LuIntDbo dbo2 = new LuIntDbo();
69
+        dbo2.fromJson(dbo.toString());
70
+        assertEquals(4242, dbo2.getInt().intValue());
71
+
72
+        dbo = new LuIntDbo(42);
73
+        assertEquals(42, dbo.getInt().intValue());
74
+
75
+        dbo = new LuIntDbo(24);
76
+        assertEquals(24, dbo.getInt().intValue());
77
+    }
78
+
79
+    @Test
80
+    public void longTest() throws Exception {
81
+        LuLongDbo dbo = new LuLongDbo();
82
+        dbo.fromJson("{\"value\": 42}");
83
+        assertEquals(42, dbo.getLong().longValue());
84
+
85
+        dbo = new LuLongDbo();
86
+        dbo.fromJson("{\"value\": null}");
87
+        assertNull(dbo.getLong());
88
+
89
+        dbo = new LuLongDbo();
90
+        dbo.fromJson("{\"value\": 24}");
91
+        assertEquals(24, dbo.getLong().longValue());
92
+        dbo.setLong((long) 4242);
93
+
94
+        LuLongDbo dbo2 = new LuLongDbo();
95
+        dbo2.fromJson(dbo.toString());
96
+        assertEquals(4242, dbo2.getLong().longValue());
97
+
98
+        dbo = new LuLongDbo((long) 42);
99
+        assertEquals(42, dbo.getLong().longValue());
100
+
101
+        dbo = new LuLongDbo((long) 24);
102
+        assertEquals(24, dbo.getLong().longValue());
103
+    }
104
+
105
+    @Test
106
+    public void doubleTest() throws Exception {
107
+        LuDoubleDbo dbo = new LuDoubleDbo();
108
+        dbo.fromJson("{\"value\": 42.125}");
109
+        assertEquals(42.125, dbo.getDouble(), 0);
110
+
111
+        dbo = new LuDoubleDbo();
112
+        dbo.fromJson("{\"value\": null}");
113
+        assertNull(dbo.getDouble());
114
+
115
+        dbo = new LuDoubleDbo();
116
+        dbo.fromJson("{\"value\": 24.125}");
117
+        assertEquals(24.125, dbo.getDouble(), 0);
118
+        dbo.setDouble(4242.125);
119
+
120
+        LuDoubleDbo dbo2 = new LuDoubleDbo();
121
+        dbo2.fromJson(dbo.toString());
122
+        assertEquals(4242.125, dbo2.getDouble(), 0);
123
+
124
+        dbo = new LuDoubleDbo(42.125);
125
+        assertEquals(42.125, dbo.getDouble(), 0);
126
+
127
+        dbo = new LuDoubleDbo(24.125);
128
+        assertEquals(24.125, dbo.getDouble(), 0);
129
+    }
130
+
131
+    @Test
132
+    public void stringTest() throws Exception {
133
+        LuStringDbo dbo = new LuStringDbo();
134
+        dbo.fromJson("{\"value\": \"42\"}");
135
+        assertEquals("42", dbo.getString());
136
+
137
+        dbo = new LuStringDbo();
138
+        dbo.fromJson("{\"value\": null}");
139
+        assertNull(dbo.getString());
140
+
141
+        dbo = new LuStringDbo();
142
+        dbo.fromJson("{\"value\": \"24\"}");
143
+        assertEquals("24", dbo.getString());
144
+        dbo.setString("4242");
145
+
146
+        LuStringDbo dbo2 = new LuStringDbo();
147
+        dbo2.fromJson(dbo.toString());
148
+        assertEquals("4242", dbo2.getString());
149
+
150
+        dbo = new LuStringDbo("42 42");
151
+        assertEquals("42 42", dbo.getString());
152
+
153
+        dbo = new LuStringDbo("24 24");
154
+        assertEquals("24 24", dbo.getString());
155
+    }
156
+
157
+    @Test
158
+    public void paginatedTest() throws Exception {
159
+        LuPaginatedDbo<LuIntDbo> dbo = new LuPaginatedDbo<>(LuIntDbo.class);
160
+        dbo.fromJson("{\"count\": 42, \"data\": [{\"value\": 1}, {\"value\": 2}, {\"value\": 3}]}");
161
+        assertEquals(42, dbo.getCount());
162
+        assertNotNull(dbo.getData());
163
+        assertEquals(3, dbo.getData().size());
164
+        assertEquals(1, dbo.getData().get(0).getInt().intValue());
165
+        assertEquals(2, dbo.getData().get(1).getInt().intValue());
166
+        assertEquals(3, dbo.getData().get(2).getInt().intValue());
167
+
168
+        dbo.setCount(24);
169
+        List<LuIntDbo> list = new Vector<>();
170
+        list.add(new LuIntDbo(10));
171
+        list.add(new LuIntDbo(20));
172
+        dbo.setData(list);;
173
+        assertEquals(24, dbo.getCount());
174
+        assertNotNull(dbo.getData());
175
+        assertEquals(2, dbo.getData().size());
176
+        assertEquals(10, dbo.getData().get(0).getInt().intValue());
177
+        assertEquals(20, dbo.getData().get(1).getInt().intValue());
178
+
179
+        HashMap<String, Object> array = dbo.toArray();
180
+        assertEquals(2, array.size());
181
+        assertTrue(array.containsKey("count"));
182
+        assertEquals(24, array.get("count"));
183
+        assertTrue(array.containsKey("data"));
184
+        assertEquals(2, ((List)array.get("data")).size());
185
+    }
186
+
187
+    @Test
188
+    public void dataAccessConfigTest() throws Exception {
189
+        LuDataAccessConfigDbo dbo = new LuDataAccessConfigDbo();
190
+        dbo.fromJson("{\"baseUrl\": \"http://api/\", \"httpUsername\": \"root\", \"httpPassword\": \"toor42\"}");
191
+        assertEquals("http://api/", dbo.getBaseUrl());
192
+        assertEquals("root", dbo.getHttpUsername());
193
+        assertEquals("toor42", dbo.getHttpPassword());
194
+        Map<String, String> headers = dbo.getHeaders();
195
+        assertEquals(1, headers.size());
196
+        assertTrue(headers.containsKey("Authorization"));
197
+        assertEquals("Basic cm9vdDp0b29yNDI=", headers.get("Authorization"));
198
+
199
+        dbo = new LuDataAccessConfigDbo();
200
+        dbo.fromJson("{\"baseUrl\": \"http://api2/\"}");
201
+        assertEquals("http://api2/", dbo.getBaseUrl());
202
+        assertNull(dbo.getHttpUsername());
203
+        assertNull(dbo.getHttpPassword());
204
+        headers = dbo.getHeaders();
205
+        assertEquals(0, headers.size());
206
+        dbo.setBaseUrl("http://api/");
207
+        dbo.setHttpUsername("root");
208
+        dbo.setHttpPassword("toor42");
209
+        assertEquals("http://api/", dbo.getBaseUrl());
210
+        assertEquals("root", dbo.getHttpUsername());
211
+        assertEquals("toor42", dbo.getHttpPassword());
212
+
213
+        HashMap<String, Object> array = dbo.toArray();
214
+        assertEquals(3, array.size());
215
+        assertTrue(array.containsKey("baseUrl"));
216
+        assertEquals("http://api/", array.get("baseUrl"));
217
+        assertTrue(array.containsKey("httpUsername"));
218
+        assertEquals("root", array.get("httpUsername"));
219
+        assertTrue(array.containsKey("httpPassword"));
220
+        assertEquals("toor42", array.get("httpPassword"));
221
+    }
222
+}

+ 10
- 0
luticateutils/src/test/java/com/luticate/utils/TestDbo.java View File

48
     protected String _aNullString;
48
     protected String _aNullString;
49
     protected Class _object = TestDbo.class;
49
     protected Class _object = TestDbo.class;
50
 
50
 
51
+    protected transient String _transientField;
52
+
51
     public byte getByte() {
53
     public byte getByte() {
52
         return _byte;
54
         return _byte;
53
     }
55
     }
264
         _object = object;
266
         _object = object;
265
     }
267
     }
266
 
268
 
269
+    public String getTransientField() {
270
+        return _transientField;
271
+    }
272
+
273
+    public void setTransientField(String transientField) {
274
+        _transientField = transientField;
275
+    }
276
+
267
     @Override
277
     @Override
268
     public boolean equals(Object o) {
278
     public boolean equals(Object o) {
269
         if (this == o) return true;
279
         if (this == o) return true;

+ 11
- 5
luticateutils/src/test/java/com/luticate/utils/TestDboTest.java View File

75
 
75
 
76
             "\"aNullString\": null," +
76
             "\"aNullString\": null," +
77
 
77
 
78
-            "\"object\": {}" +
78
+            "\"object\": {}," +
79
+
80
+            "\"transientField\": \"a transient field\"" +
79
 
81
 
80
             "}";
82
             "}";
81
 
83
 
145
         assertNull(test.getaNullString());
147
         assertNull(test.getaNullString());
146
         assertNull(test.getObject());
148
         assertNull(test.getObject());
147
 
149
 
150
+        assertNull(test.getTransientField());
151
+
148
         assertEquals(test, test);
152
         assertEquals(test, test);
149
     }
153
     }
150
 
154
 
151
     @Test
155
     @Test
152
     public void deserializeTest() throws Exception {
156
     public void deserializeTest() throws Exception {
153
         TestDbo test = new TestDbo();
157
         TestDbo test = new TestDbo();
154
-        test.fromString(TEST_DBO_JSON);
158
+        test.fromJson(TEST_DBO_JSON);
155
         testTestDbo(test);
159
         testTestDbo(test);
156
     }
160
     }
157
 
161
 
159
     public void serializeTest() throws Exception
163
     public void serializeTest() throws Exception
160
     {
164
     {
161
         TestDbo test = new TestDbo();
165
         TestDbo test = new TestDbo();
162
-        test.fromString(TEST_DBO_JSON);
166
+        test.fromJson(TEST_DBO_JSON);
163
         JSONObject json = test.toJson();
167
         JSONObject json = test.toJson();
164
 
168
 
169
+        assertFalse(json.has("transientField"));
170
+
165
         TestDbo test2 = new TestDbo();
171
         TestDbo test2 = new TestDbo();
166
         test2.fromJson(json);
172
         test2.fromJson(json);
167
 
173
 
172
     public void serializeStringTest() throws Exception
178
     public void serializeStringTest() throws Exception
173
     {
179
     {
174
         TestDbo test = new TestDbo();
180
         TestDbo test = new TestDbo();
175
-        test.fromString(TEST_DBO_JSON);
181
+        test.fromJson(TEST_DBO_JSON);
176
 
182
 
177
         TestDbo test2 = new TestDbo();
183
         TestDbo test2 = new TestDbo();
178
-        test2.fromString(test.toString());
184
+        test2.fromJson(test.toString());
179
 
185
 
180
         testTestDbo(test2);
186
         testTestDbo(test2);
181
     }
187
     }

Loading…
Cancel
Save