#3533 CLI list-hosts fix when list of channels is empty
Merged a year ago by tkopecek. Opened 2 years ago by jcupova.
jcupova/koji issue-3532  into  master

file modified
+4 -8
@@ -3108,8 +3108,7 @@ 

          opts['ready'] = options.ready

      if options.enabled is not None:

          opts['enabled'] = options.enabled

-     tmp_list = sorted([(x['name'], x) for x in session.listHosts(**opts)])

-     hosts = [x[1] for x in tmp_list]

+     hosts = sorted(session.listHosts(**opts), key=lambda x: x['name'])

  

      if not hosts:

          warn("No hosts found.")
@@ -3149,11 +3148,11 @@ 

      if options.show_channels:

          with session.multicall() as m:

              result = [m.listChannels(host['id']) for host in hosts]

-         first_line_channel = result[0].result[0]

          for host, channels in zip(hosts, result):

              list_channels = []

              for c in channels.result:

-                 if 'enabled' in first_line_channel:

+                 # enabled column was added in Koji 1.26

+                 if c.get('enabled') is not None:

                      if c['enabled']:

                          list_channels.append(c['name'])

                      else:
@@ -3162,10 +3161,7 @@ 

                      list_channels.append(c['name'])

              host['channels'] = ','.join(sorted(list_channels))

  

-     if hosts:

-         longest_host = max([len(h['name']) for h in hosts])

-     else:

-         longest_host = 8

+     longest_host = max([len(h['name']) for h in hosts])

  

      if not options.quiet:

          hdr = "{hostname:<{longest_host}} Enb Rdy Load/Cap  Arches           " \

@@ -47,6 +47,14 @@ 

              os.environ['TZ'] = self.original_timezone

              time.tzset()

  

+     def __vm(self, result):

+         m = koji.VirtualCall('mcall_method', [], {})

+         if isinstance(result, dict) and result.get('faultCode'):

+             m._result = result

+         else:

+             m._result = (result,)

+         return m

+ 

      @mock.patch('sys.stdout', new_callable=StringIO)

      def test_list_hosts_valid_without_quiet(self, stdout):

          self.options.quiet = False
@@ -224,3 +232,54 @@ 

          self.session.listHosts.assert_called_once_with()

          self.session.getLastHostUpdate.assert_called_once_with(self.list_hosts[0]['id'], ts=True)

          self.ensure_connection_mock.assert_called_once_with(self.session, self.options)

+ 

+     @mock.patch('sys.stdout', new_callable=StringIO)

+     def test_list_hosts_with_show_channels(self, stdout):

+         self.options.quiet = False

+         host_update = 1615875554.862938

+         expected = """Hostname    Enb Rdy Load/Cap  Arches           Last Update                         Channels

+ -------------------------------------------------------------------------------------------

+ kojibuilder N   Y    0.0/2.0  x86_64           Tue, 16 Mar 2021 06:19:14 UTC       *test,default\n"""

+         list_channels = [

+             {'id': 1, 'name': 'default', 'enabled': True, 'comment': 'test-comment-1',

+              'description': 'test-description-1'},

+             {'id': 2, 'name': 'test', 'enabled': False, 'comment': 'test-comment-2',

+              'description': 'test-description-2'},

+         ]

+ 

+         self.session.getLastHostUpdate.return_value = host_update

+         self.session.multiCall.return_value = [[host_update]]

+         mcall = self.session.multicall.return_value.__enter__.return_value

+         mcall.listChannels.return_value = self.__vm(list_channels)

+ 

+         self.session.listHosts.return_value = self.list_hosts

+         rv = anon_handle_list_hosts(self.options, self.session, ['--show-channels'])

+         self.assertEqual(rv, None)

+         self.assert_console_message(stdout, expected)

+         self.session.listHosts.assert_called_once_with()

+         self.session.getLastHostUpdate.assert_called_once_with(self.list_hosts[0]['id'], ts=True)

+         self.ensure_connection_mock.assert_called_once_with(self.session, self.options)

+         self.session.listChannels.assert_not_called()

+ 

+     @mock.patch('sys.stdout', new_callable=StringIO)

+     def test_list_hosts_with_show_channels_empty(self, stdout):

+         self.options.quiet = False

+         host_update = 1615875554.862938

+         expected = """Hostname    Enb Rdy Load/Cap  Arches           Last Update                         Channels

+ -------------------------------------------------------------------------------------------

+ kojibuilder N   Y    0.0/2.0  x86_64           Tue, 16 Mar 2021 06:19:14 UTC       \n"""

+         list_channels = []

+ 

+         self.session.getLastHostUpdate.return_value = host_update

+         self.session.multiCall.return_value = [[host_update]]

+         mcall = self.session.multicall.return_value.__enter__.return_value

+         mcall.listChannels.return_value = self.__vm(list_channels)

+ 

+         self.session.listHosts.return_value = self.list_hosts

+         rv = anon_handle_list_hosts(self.options, self.session, ['--show-channels'])

+         self.assertEqual(rv, None)

+         self.assert_console_message(stdout, expected)

+         self.session.listHosts.assert_called_once_with()

+         self.session.getLastHostUpdate.assert_called_once_with(self.list_hosts[0]['id'], ts=True)

+         self.ensure_connection_mock.assert_called_once_with(self.session, self.options)

+         self.session.listChannels.assert_not_called()

It should stay here for backward (hub) compatibility.

rebased onto 4bd9d5a459e3d47b8fcf6883e3c08b3099b69afb

2 years ago

rebased onto b8dec2abd894a88a486e11df1ec96ca38514864c

2 years ago

rebased onto 8ca6d52868a88e6f72745683073b8e72adefe9fc

2 years ago

rebased onto 50ac1ad

2 years ago

Metadata Update from @tkopecek:
- Pull-request tagged with: testing-ready

2 years ago

Metadata Update from @mfilip:
- Pull-request tagged with: testing-done

a year ago

Commit a55467a fixes this pull-request

Pull-Request has been merged by tkopecek

a year ago