From 87da5f15ea314d53d97cee5f9fd13b4f83455256 Mon Sep 17 00:00:00 2001
From: Joey Castillo <joeycastillo@utexas.edu>
Date: Tue, 5 Jul 2022 22:53:04 -0500
Subject: new tests

---
 apps/functional-test/app.c           | 38 +++++++++++-------
 apps/sensor-board-test/app.c         | 75 ++++++++++++++++++++++++++++++++++++
 apps/sensor-board-test/make/Makefile | 10 +++++
 3 files changed, 109 insertions(+), 14 deletions(-)
 create mode 100644 apps/sensor-board-test/app.c
 create mode 100755 apps/sensor-board-test/make/Makefile

diff --git a/apps/functional-test/app.c b/apps/functional-test/app.c
index 18599512..179bea8b 100644
--- a/apps/functional-test/app.c
+++ b/apps/functional-test/app.c
@@ -13,6 +13,8 @@ void app_setup(void) {
 
     watch_enable_buzzer();
 
+    watch_enable_digital_output(RED);
+    watch_enable_digital_output(GREEN);
     watch_enable_digital_input(BTN_ALARM);
     watch_enable_digital_input(BTN_LIGHT);
     watch_enable_digital_input(BTN_MODE);
@@ -30,34 +32,42 @@ void app_wake_from_standby(void) {
 bool app_loop(void) {
     static int last_button = 0;
     static int button = 0;
-    static int16_t loop = 0;
+    static int8_t loop = 0;
 
+    watch_set_pin_level(GREEN, false);
+    watch_set_pin_level(RED, false);
     if (watch_get_pin_level(BTN_ALARM)) {
+        watch_set_pin_level(GREEN, true);
         button = 1;
-    }
-    if (watch_get_pin_level(BTN_LIGHT)) {
+    } else if (watch_get_pin_level(BTN_LIGHT)) {
+        watch_set_pin_level(RED, true);
         button = 2;
-    }
-    if (watch_get_pin_level(BTN_MODE)) {
+    } else if (watch_get_pin_level(BTN_MODE)) {
+        watch_set_pin_level(GREEN, true);
+        watch_set_pin_level(RED, true);
         button = 3;
     }
 
     if (button != last_button) {
         last_button = button;
-        watch_buzzer_play_note(BUZZER_NOTE_C8, 50);
+        watch_buzzer_play_note(BUZZER_NOTE_C8, 100);
     }
 
+    static const bool segmap[3][24] = {
+       //0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
+        {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0},
+        {0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1},
+        {1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1}
+    };
+
     for(int com = 0; com < 3; com++) {
         for(int seg = 0; seg < 24; seg++) {
-            if (loop > 0) {
-                if (seg % 2 == 0) watch_set_pixel(com, seg);
-                else watch_set_pixel(com, seg);
-            } else {
-                if (seg % 2 == 1) watch_set_pixel(com, seg);
-                else watch_set_pixel(com, seg);
-            }
+            if (segmap[com][seg]) (loop >= 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg);
+            else (loop < 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg);
         }
     }
 
-    return true;
+    loop++;
+
+    return false;
 }
diff --git a/apps/sensor-board-test/app.c b/apps/sensor-board-test/app.c
new file mode 100644
index 00000000..d7da190a
--- /dev/null
+++ b/apps/sensor-board-test/app.c
@@ -0,0 +1,75 @@
+#include <stdio.h>
+#include <string.h>
+#include "watch.h"
+
+bool even = false;
+
+static void cb_tick(void) {
+    even = !even;
+}
+
+void app_init(void) {
+}
+
+void app_wake_from_backup(void) {
+}
+
+void app_setup(void) {
+    watch_enable_digital_output(RED);
+    watch_enable_digital_output(GREEN);
+    watch_enable_digital_output(A0);
+    watch_enable_digital_output(SCL);
+    watch_enable_digital_output(SDA);
+    watch_enable_digital_output(A1);
+    watch_enable_digital_output(A2);
+    watch_enable_digital_output(A3);
+    watch_enable_digital_output(A4);
+
+    watch_set_pin_level(A0, false);
+    watch_set_pin_level(SCL, false);
+    watch_set_pin_level(SDA, false);
+    watch_set_pin_level(A1, false);
+    watch_set_pin_level(A2, false);
+    watch_set_pin_level(A3, false);
+    watch_set_pin_level(A4, false);
+
+    watch_rtc_register_periodic_callback(cb_tick, 2);
+}
+
+void app_prepare_for_standby(void) {
+}
+
+void app_wake_from_standby(void) {
+}
+
+bool app_loop(void) {
+    watch_date_time date_time = watch_rtc_get_date_time();
+    char buf[16];
+    sprintf(buf, "%2d:%02d:%02d: ", date_time.unit.hour, date_time.unit.minute, date_time.unit.second);
+    printf(buf);
+    if (even) {
+        printf("Even\n");
+        watch_set_pin_level(RED, false);
+        watch_set_pin_level(GREEN, true);
+        watch_set_pin_level(A0, true);
+        watch_set_pin_level(SCL, false);
+        watch_set_pin_level(SDA, true);
+        watch_set_pin_level(A1, false);
+        watch_set_pin_level(A2, true);
+        watch_set_pin_level(A3, false);
+        watch_set_pin_level(A4, true);
+    } else {
+        printf("Odd\n");
+        watch_set_pin_level(RED, true);
+        watch_set_pin_level(GREEN, false);
+        watch_set_pin_level(A0, false);
+        watch_set_pin_level(SCL, true);
+        watch_set_pin_level(SDA, false);
+        watch_set_pin_level(A1, true);
+        watch_set_pin_level(A2, false);
+        watch_set_pin_level(A3, true);
+        watch_set_pin_level(A4, false);
+    }
+
+    return true;
+}
diff --git a/apps/sensor-board-test/make/Makefile b/apps/sensor-board-test/make/Makefile
new file mode 100755
index 00000000..c66ad20c
--- /dev/null
+++ b/apps/sensor-board-test/make/Makefile
@@ -0,0 +1,10 @@
+TOP = ../../..
+include $(TOP)/make.mk
+
+INCLUDES += \
+  -I../
+
+SRCS += \
+  ../app.c
+
+include $(TOP)/rules.mk
-- 
cgit v1.2.3