parsers_test.py 3.23 KB
Newer Older
Taylor Robie's avatar
Taylor Robie committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# Copyright 2017 The TensorFlow Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ==============================================================================

import argparse
import unittest

19
import tensorflow as tf  # pylint: disable=g-bad-import-order
Taylor Robie's avatar
Taylor Robie committed
20
21
22
23
24
25
26
27
28
29
30
31

from official.utils.arg_parsers import parsers


class TestParser(argparse.ArgumentParser):
  """Class to test canned parser functionality."""

  def __init__(self):
    super(TestParser, self).__init__(parents=[
        parsers.BaseParser(),
        parsers.PerformanceParser(num_parallel_calls=True, inter_op=True,
                                  intra_op=True, use_synthetic_data=True),
32
        parsers.ImageModelParser(data_format=True),
33
        parsers.BenchmarkParser(benchmark_log_dir=True, bigquery_uploader=True)
Taylor Robie's avatar
Taylor Robie committed
34
35
36
37
38
39
40
41
42
43
44
45
46
    ])


class BaseTester(unittest.TestCase):

  def test_default_setting(self):
    """Test to ensure fields exist and defaults can be set.
    """

    defaults = dict(
        data_dir="dfgasf",
        model_dir="dfsdkjgbs",
        train_epochs=534,
47
        epochs_between_evals=15,
Taylor Robie's avatar
Taylor Robie committed
48
        batch_size=256,
49
        hooks=["LoggingTensorHook"],
Taylor Robie's avatar
Taylor Robie committed
50
51
52
53
54
55
56
57
58
59
60
61
62
        num_parallel_calls=18,
        inter_op_parallelism_threads=5,
        intra_op_parallelism_thread=10,
        data_format="channels_first"
    )

    parser = TestParser()
    parser.set_defaults(**defaults)

    namespace_vars = vars(parser.parse_args([]))
    for key, value in defaults.items():
      assert namespace_vars[key] == value

63
64
65
  def test_benchmark_setting(self):
    defaults = dict(
        hooks=["LoggingMetricHook"],
66
67
        benchmark_log_dir="/tmp/12345",
        gcp_project="project_abc",
68
69
70
71
72
73
74
75
76
    )

    parser = TestParser()
    parser.set_defaults(**defaults)

    namespace_vars = vars(parser.parse_args([]))
    for key, value in defaults.items():
      assert namespace_vars[key] == value

Taylor Robie's avatar
Taylor Robie committed
77
78
79
80
81
82
83
84
85
86
  def test_booleans(self):
    """Test to ensure boolean flags trigger as expected.
    """

    parser = TestParser()
    namespace = parser.parse_args(["--multi_gpu", "--use_synthetic_data"])

    assert namespace.multi_gpu
    assert namespace.use_synthetic_data

87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
  def test_parse_dtype_info(self):
    parser = TestParser()
    for dtype_str, tf_dtype, loss_scale in [["fp16", tf.float16, 128],
                                            ["fp32", tf.float32, 1]]:
      args = parser.parse_args(["--dtype", dtype_str])
      parsers.parse_dtype_info(args)

      assert args.dtype == tf_dtype
      assert args.loss_scale == loss_scale

      args = parser.parse_args(["--dtype", dtype_str, "--loss_scale", "5"])
      parsers.parse_dtype_info(args)

      assert args.loss_scale == 5

    with self.assertRaises(SystemExit):
      parser.parse_args(["--dtype", "int8"])

Taylor Robie's avatar
Taylor Robie committed
105
106
107

if __name__ == "__main__":
  unittest.main()