* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include <config.h>
g_free(s);
}
+static void test_period(uint64_t v_p, uint64_t v_q, const char *expected)
+{
+ char *s;
+
+ s = sr_period_string(v_p, v_q);
+ fail_unless(s != NULL);
+ fail_unless(!strcmp(s, expected),
+ "Invalid result for '%s': %s.", expected, s);
+ g_free(s);
+}
+
static void test_rational(const char *input, struct sr_rational expected)
{
int ret;
}
END_TEST
+START_TEST(test_hz_period)
+{
+ test_period(1, 1, "1 s");
+ test_period(1, 5, "200 ms");
+ test_period(1, 72, "13.889 ms");
+ test_period(1, 388, "2.577 ms");
+ test_period(10, 1000, "10 ms");
+
+ /* Again, but now using SR_HZ(). */
+ test_period(1, SR_HZ(1), "1 s");
+ test_period(1, SR_HZ(5), "200 ms");
+ test_period(1, SR_HZ(72), "13.889 ms");
+ test_period(1, SR_HZ(388), "2.577 ms");
+ test_period(10, SR_HZ(100), "100 ms");
+}
+END_TEST
+
+START_TEST(test_ghz_period)
+{
+ /* Note: Numbers > 2^32 need a ULL suffix. */
+ test_period(1, 1000000000, "1 ns");
+ test_period(1, 5000000000ULL, "200 ps");
+ test_period(1, 72000000000ULL, "13.889 ps");
+ test_period(1, 388000000000ULL, "2.577 ps");
+ test_period(10, 1000000000000, "10 ps");
+ test_period(200, 1000000000000ULL, "200 ps");
+
+ /* Again, but now using SR_GHZ(). */
+ test_period(1, SR_GHZ(1), "1 ns");
+ test_period(1, SR_GHZ(5), "200 ps");
+ test_period(1, SR_GHZ(72), "13.889 ps");
+ test_period(1, SR_GHZ(388), "2.577 ps");
+ test_period(10, SR_GHZ(1), "10 ns");
+ test_period(200, SR_GHZ(1000), "200 ps");
+}
+END_TEST
+
START_TEST(test_integral)
{
test_rational("1", (struct sr_rational){1, 1});
tcase_add_test(tc, test_khz);
tcase_add_test(tc, test_mhz);
tcase_add_test(tc, test_ghz);
+ tcase_add_test(tc, test_hz_period);
+ tcase_add_test(tc, test_ghz_period);
tcase_add_test(tc, test_integral);
tcase_add_test(tc, test_fractional);
tcase_add_test(tc, test_exponent);