pbs_standing_resv_quasihang.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # coding: utf-8
  2. # Copyright (C) 1994-2018 Altair Engineering, Inc.
  3. # For more information, contact Altair at www.altair.com.
  4. #
  5. # This file is part of the PBS Professional ("PBS Pro") software.
  6. #
  7. # Open Source License Information:
  8. #
  9. # PBS Pro is free software. You can redistribute it and/or modify it under the
  10. # terms of the GNU Affero General Public License as published by the Free
  11. # Software Foundation, either version 3 of the License, or (at your option) any
  12. # later version.
  13. #
  14. # PBS Pro is distributed in the hope that it will be useful, but WITHOUT ANY
  15. # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  16. # FOR A PARTICULAR PURPOSE.
  17. # See the GNU Affero General Public License for more details.
  18. #
  19. # You should have received a copy of the GNU Affero General Public License
  20. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. #
  22. # Commercial License Information:
  23. #
  24. # For a copy of the commercial license terms and conditions,
  25. # go to: (http://www.pbspro.com/UserArea/agreement.html)
  26. # or contact the Altair Legal Department.
  27. #
  28. # Altair’s dual-license business model allows companies, individuals, and
  29. # organizations to create proprietary derivative works of PBS Pro and
  30. # distribute them - whether embedded or bundled with other software -
  31. # under a commercial license agreement.
  32. #
  33. # Use of Altair’s trademarks, including but not limited to "PBS™",
  34. # "PBS Professional®", and "PBS Pro™" and Altair’s logos is subject to Altair's
  35. # trademark licensing policies.
  36. from tests.performance import *
  37. class StandingResvQuasihang(TestPerformance):
  38. """
  39. This test suite aims at testing the quasihang caused by a MoM HUP
  40. when there is a standing reservation with more than a 1000 instances.
  41. Without the fix, the server takes a lot of time to respond to a client.
  42. With the fix, the amount of time is significantly reduced.
  43. """
  44. def setUp(self):
  45. TestPerformance.setUp(self)
  46. # Set PBS_TZID, needed for standing reservation.
  47. if 'PBS_TZID' in self.conf:
  48. self.tzone = self.conf['PBS_TZID']
  49. elif 'PBS_TZID' in os.environ:
  50. self.tzone = os.environ['PBS_TZID']
  51. else:
  52. self.logger.info('Timezone not set, using Asia/Kolkata')
  53. self.tzone = 'Asia/Kolkata'
  54. a = {'resources_available.ncpus': 2}
  55. self.server.create_vnodes('vnode', a, num=2000, mom=self.mom,
  56. usenatvnode=True)
  57. @timeout(6000)
  58. def test_time_for_stat_after_mom_hup(self):
  59. """
  60. This test case submits a standing reservation with 2000 instances,
  61. HUPS the MoM, stats the reservation and finds the amount of time
  62. the server took to respond.
  63. The test case is not designed to pass/fail on builds with/without
  64. the fix.
  65. """
  66. start = int(time.time()) + 3600
  67. attrs = {'Resource_List.select': "64:ncpus=2",
  68. 'reserve_start': start,
  69. 'reserve_duration': 2000,
  70. 'reserve_timezone': self.tzone,
  71. 'reserve_rrule': "FREQ=HOURLY;BYHOUR=1,2,3,4,5;COUNT=2000"}
  72. rid = self.server.submit(Reservation(TEST_USER, attrs))
  73. attrs = {'reserve_state': (MATCH_RE, 'RESV_CONFIRMED|2')}
  74. # it takes a while for all the instances of the reservation to get
  75. # confirmed, hence the interval of 5 seconds.
  76. self.server.expect(RESV, attrs, id=rid, interval=5)
  77. self.mom.signal('-HUP')
  78. # sleep for 5 seconds so that the HUP takes its effect.
  79. time.sleep(5)
  80. now1 = int(time.time())
  81. attrs = {'reserve_state': (MATCH_RE, 'RESV_CONFIRMED|2')}
  82. self.server.expect(RESV, attrs, id=rid)
  83. now2 = int(time.time())
  84. self.logger.info("pbs_rstat took %d seconds to return\n",
  85. (now2 - now1))