smoke_test.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. from __future__ import annotations
  2. import argparse
  3. import json
  4. from typing import Any
  5. from m2_mcp.config_api import (
  6. get_command_log,
  7. get_ai_online_v2,
  8. search_ai_rcmd_operations,
  9. search_ai_systems,
  10. set_multi_values,
  11. )
  12. def _parse_bool(raw: str) -> bool:
  13. text = str(raw).strip().lower()
  14. if text in {"1", "true", "yes", "y", "on"}:
  15. return True
  16. if text in {"0", "false", "no", "n", "off"}:
  17. return False
  18. raise argparse.ArgumentTypeError(f"invalid boolean value: {raw}")
  19. def _print(payload: Any) -> None:
  20. print(json.dumps(payload, ensure_ascii=False, indent=2))
  21. def build_parser() -> argparse.ArgumentParser:
  22. parser = argparse.ArgumentParser(description="Smoke test for instrument config MCP upstream APIs")
  23. subparsers = parser.add_subparsers(dest="command", required=True)
  24. p = subparsers.add_parser("search-ai-systems")
  25. p.add_argument("--project-key", required=True)
  26. p.add_argument("--keyword", default="")
  27. p.add_argument("--page-size", type=int, default=20)
  28. p.add_argument("--page-num", type=int, default=1)
  29. p.add_argument("--order-by", nargs="*", default=["-id"])
  30. p = subparsers.add_parser("search-ai-rcmd-operations")
  31. p.add_argument("--project-key", required=True)
  32. p.add_argument("--codes", nargs="+", required=True)
  33. p.add_argument("--end", required=True)
  34. p.add_argument("--page-size", type=int, default=20)
  35. p.add_argument("--page-num", type=int, default=1)
  36. p.add_argument("--order", default="-create_time")
  37. p = subparsers.add_parser("get-ai-online-v2")
  38. p.add_argument("--project-key", required=True)
  39. p.add_argument("--codes", nargs="+", required=True)
  40. p = subparsers.add_parser("get-command-log")
  41. p.add_argument("--project-key", required=True)
  42. p.add_argument("--point-id", required=True)
  43. p.add_argument("--begin", type=int, required=True)
  44. p.add_argument("--end", type=int, required=True)
  45. p.add_argument("--page-size", type=int, default=20)
  46. p.add_argument("--page-num", type=int, default=1)
  47. p.add_argument("--export", type=_parse_bool, default=False)
  48. p = subparsers.add_parser("set-multi-values")
  49. p.add_argument("--project-key", required=True)
  50. p.add_argument("--points-json", required=True)
  51. p.add_argument("--from", dest="from_", default="M2_BACKEND")
  52. return parser
  53. def main() -> None:
  54. parser = build_parser()
  55. args = parser.parse_args()
  56. if args.command == "search-ai-systems":
  57. _print(
  58. search_ai_systems(
  59. args.project_key,
  60. keyword=args.keyword,
  61. page_size=args.page_size,
  62. page_num=args.page_num,
  63. order_by=args.order_by,
  64. )
  65. )
  66. return
  67. if args.command == "search-ai-rcmd-operations":
  68. _print(
  69. search_ai_rcmd_operations(
  70. args.project_key,
  71. codes=args.codes,
  72. end=args.end,
  73. page_size=args.page_size,
  74. page_num=args.page_num,
  75. order=args.order,
  76. )
  77. )
  78. return
  79. if args.command == "get-ai-online-v2":
  80. _print(get_ai_online_v2(args.project_key, codes=args.codes))
  81. return
  82. if args.command == "get-command-log":
  83. _print(
  84. get_command_log(
  85. args.project_key,
  86. point_id=args.point_id,
  87. begin=args.begin,
  88. end=args.end,
  89. page_size=args.page_size,
  90. page_num=args.page_num,
  91. export=args.export,
  92. )
  93. )
  94. return
  95. if args.command == "set-multi-values":
  96. _print(set_multi_values(args.project_key, points=json.loads(args.points_json), from_=args.from_))
  97. return
  98. raise ValueError(f"unsupported command: {args.command}")
  99. if __name__ == "__main__":
  100. main()