diff --git a/json/port_test.pl b/json/port_test.pl index e62abeb1..0bc40567 100755 --- a/json/port_test.pl +++ b/json/port_test.pl @@ -16,7 +16,7 @@ use LWP::UserAgent; use Data::Dumper; use JSON; use lib '/home/lanforge/scripts'; -use LANforge::JsonUtils qw(logg err json_request get_links_from); +use LANforge::JsonUtils qw(logg err json_request get_links_from get_thru json_post get_port_names); package main; # Default values for ye ole cmd-line args. @@ -48,19 +48,150 @@ $::HostUri = "http://$Host:$Port"; my $uri = "/shelf/1"; my $rh = json_request($uri); my $ra_links = get_links_from($rh, 'resources'); - -#print Dumper($ra_links); +my @links2= (); +my $ra_alias_links = []; +# TODO: make this a JsonUtils::list_ports() for $uri (@$ra_links) { $uri =~ s{/resource}{/port}g; $uri .= "/list"; - logg("requesting $uri"); - + #logg("requesting $uri"); $rh = json_request($uri); - print Dumper($rh); - my $ra_links2 = get_links_from($rh, 'interfaces'); - for my $uri2 (@$ra_links2) { - logg("found $uri2"); - } + #print Dumper($rh); + push( @$ra_alias_links, @{get_port_names($rh, 'interfaces')}); + push(@links2, @{get_links_from($rh, 'interfaces')}); + #logg("\nfound: "); + #logg(@links2); +} +#print Dumper($ra_alias_links); + +# destroy stations on resource 3, 7, 8 +my @radios = (); +my @destroy_me = (); +for my $rh_alias_link (@$ra_alias_links) { + push(@destroy_me, $rh_alias_link) + if (($rh_alias_link->{'uri'} =~m{^/port/1/[3678]/}) + && ($rh_alias_link->{'alias'} =~m{^sta})); + push(@radios, $rh_alias_link) + if (($rh_alias_link->{'uri'} =~m{^/port/1/[3678]/}) + && ($rh_alias_link->{'alias'} =~m{^wiphy})); +} +logg("\nDestroying these: "); +#print Dumper(@destroy_me); +for my $rh_target (@destroy_me) { + my $alias = $rh_target->{'alias'}; + my @hunks = split(/[\/]/, $rh_target->{'uri'}); + + # TODO: create JsonUtils::rm_vlan($eid, $alias) + my $rh_data = { + 'shelf'=>1, 'resource'=>$hunks[3], 'port'=>$alias + }; + #print Dumper($rh_data); + json_post("/cli-json/rm_vlan", $rh_data); + sleep 0.1; } -# +# this really should poll for ports to wait for them to disappear +sleep 5; + +my @new_stations = (); +logg("\nCreating new stations on these: "); +#print Dumper(\@radios); +my $rh_radio; +my $radio_name; +my $resource; +my $range; +my $radio_num; +for $rh_radio (@radios) { + $radio_name = $rh_radio->{'alias'}; + my @hunks = split(/[\/]/, $rh_radio->{'uri'}); + ($radio_num) = $radio_name =~ /wiphy(\d+)/; + $resource = $hunks[3]; + $range = ($resource * 1000) + ($radio_num * 100); + logg("\n/cli-json/add_sta = "); + for (my $i = $range; $i < ($range+20); $i++) { + # TODO: create JsonUtils::add_sta($eid, $alias...) + my $rh_data = { + 'shelf'=>1, + 'resource'=>$resource, + 'radio'=>$radio_name, + 'sta_name'=>'sta'.$i, + 'flags'=>68862086144, # has port-down set + 'ssid'=>'idtest-1200-wpa2', + 'key'=>'idtest-1200-wpa2', + 'mac'=>'xx:xx:xx:xx:*:xx', + 'mode'=>0, + 'rate'=>'DEFAULT' + }; + #print Dumper($rh_data); + logg(" $radio_name/sta$i "); + json_post("/cli-json/add_sta", $rh_data); + sleep 0.1; + } +} +sleep 2; +for $rh_radio (@radios) { + $radio_name = $rh_radio->{'alias'}; + my @hunks = split(/[\/]/, $rh_radio->{'uri'}); + $resource = $hunks[3]; + $range = ($resource * 1000) + ($radio_num * 100); + for (my $i = $range; $i < ($range+20); $i++) { + my $rh_data = { + 'shelf'=>1, + 'resource'=>$resource, + 'port'=>'sta'.$i, + 'cmd_flags'=>0, + 'current_flags'=>2147483648, + 'interest'=>16386 + }; + # TODO: create JsonUtils::set_dhcp($eid, $alias, $on_off) + json_post("/cli-json/set_port", $rh_data); + sleep 0.1; + } +} +sleep 2; +for $uri (@$ra_links) { + $uri =~ s{/resource}{/port}g; + $uri .= "/list" + if ($uri !~ m{/list$}); + $rh = json_request($uri); + push( @$ra_alias_links, @{get_port_names($rh, 'interfaces')}); + push(@links2, @{get_links_from($rh, 'interfaces')}); +} +exit; + +# ports down +my $set_port = "/cli-json/set_port"; +logg("\nsetting ports down: "); +for my $port_uri (@links2) { + $rh = json_request($port_uri); + my $device = get_thru('interface', 'device', $rh); + next if ($device !~ /^sta/); + logg($device." "); + my $port = get_thru('interface', 'port', $rh); + my @hunks = split(/\./, $port); + my $resource = $hunks[1]; + my %post = ( + "shelf" => 1, "resource" => 0+$resource, "port" => $device, + "current_flags" => 1, "interest" => 8388610 + ); + my $rh_response = json_post($set_port, \%post); +} +sleep 2; +logg("\nsetting ports up "); +for my $port_uri (@links2) { + $rh = json_request($port_uri); + my $device = get_thru('interface', 'device', $rh); + next if ($device !~ /^sta/); + logg($device." "); + my $port = get_thru('interface', 'port', $rh); + my @hunks = split(/\./, $port); + my $resource = $hunks[1]; + # 'shelf=1&resource=2&port=vap2000&cmd_flags=0¤t_flags=0&interest=8388610' + my %post = ( + "shelf" => 1, "resource" => 0+$resource, "port" => $device, + "current_flags" => 0, "interest" => 8388610 + ); + my $rh_response = json_post($set_port, \%post); +} + +# \ No newline at end of file