# encoding: utf-8
require File.dirname(__FILE__) + '/../spec_helper'

module SendGrid4r::REST
  describe IpAccessManagement do
    describe 'integration test', :it do
      before do
        Dotenv.load
        @client = SendGrid4r::Client.new(api_key: ENV['SILVER_API_KEY'])

        # clean up test env(whitelisted_ips)
        @ip1 = '192.168.0.1/32'
        @ip2 = '1.12.34.56/32'
        ips = @client.get_whitelisted_ips
        ips.result.each do |whitelisted_ip|
          @client.delete_whitelisted_ip(
            rule_id: whitelisted_ip.id
          ) if whitelisted_ip.ip == @ip1 || whitelisted_ip.ip == @ip2
        end
        @ips = @client.post_whitelisted_ips(ips: [@ip1])
        @ips.result.each do |ip|
          @id1 = ip.id if ip.ip == @ip1
        end
      end

      context 'without block call' do
        it '#get_ip_activities without limit' do
          activities = @client.get_ip_activities
          expect(activities).to be_a(
            IpAccessManagement::IpActivities
          )
          activities.result.each do |activity|
            expect(activity).to be_a(
              IpAccessManagement::IpActivity
            )
          end
        end

        it '#get_ip_activities with limit' do
          activities = @client.get_ip_activities(limit: 1)
          expect(activities).to be_a(
            IpAccessManagement::IpActivities
          )
          activities.result.each do |activity|
            expect(activity).to be_a(
              IpAccessManagement::IpActivity
            )
          end
        end

        it '#get_whitelisted_ips' do
          ips = @client.get_whitelisted_ips
          expect(ips).to be_a(
            IpAccessManagement::WhitelistedIps
          )
        end

        it '#post_whitelisted_ips' do
          ips = @client.post_whitelisted_ips(ips: [@ip2])
          expect(ips).to be_a(
            IpAccessManagement::WhitelistedIps
          )
        end

        it '#delete_whitelisted_ips' do
          @client.delete_whitelisted_ips(ids: [@id1])
        end

        it '#get_whitelisted_ip' do
          whitelisted_ip = @client.get_whitelisted_ip(rule_id: @id1)
          expect(whitelisted_ip).to be_a(
            IpAccessManagement::WhitelistedIp
          )
        end

        it '#delete_whitelisted_ip' do
          @client.delete_whitelisted_ip(rule_id: @id1)
        end
      end
    end

    describe 'unit test', :ut do
      let(:client) do
        SendGrid4r::Client.new(api_key: '')
      end

      let(:ip_activities) do
        '{'\
          '"result": ['\
            '{'\
              '"allowed": false,'\
              '"auth_method": "basic",'\
              '"first_at": 1444087966,'\
              '"ip": "1.1.1.1",'\
              '"last_at": 1444406672,'\
              '"location": "Australia"'\
            '}, {'\
              '"allowed": false,'\
              '"auth_method": "basic",'\
              '"first_at": 1444087505,'\
              '"ip": "1.2.3.48",'\
              '"last_at": 1444087505,'\
              '"location": "Mukilteo, Washington"'\
            '}'\
          ']'\
        '}'
      end

      let(:whitelisted_ips) do
        '{'\
          '"result": ['\
            '{'\
              '"id": 1, "ip": "192.168.1.1/32", '\
              '"created_at": 1441824715, "updated_at": 1441824715'\
            '},'\
            '{'\
              '"id": 2, "ip": "192.168.1.2/32", '\
              '"created_at": 1441824715, "updated_at": 1441824715'\
            '},'\
            '{'\
              '"id": 3, "ip": "192.168.1.3/32", '\
              '"created_at": 1441824715, "updated_at": 1441824715'\
            '}'\
          ']'\
        '}'
      end

      let(:whitelisted_ip) do
        '{'\
          '"result": {'\
            '"created_at": 1459011215,'\
            '"id": 1,'\
            '"ip": "192.168.1.1/32",'\
            '"updated_at": 1459011215'\
          '}'\
        '}'
      end

      it '#get_ip_activities' do
        allow(client).to receive(:execute).and_return(ip_activities)
        actual = client.get_ip_activities
        expect(actual).to be_a(IpAccessManagement::IpActivities)
        actual.result.each do |activity|
          expect(activity).to be_a(
            IpAccessManagement::IpActivity
          )
        end
      end

      it '#get_whitelisted_ips' do
        allow(client).to receive(:execute).and_return(whitelisted_ips)
        actual = client.get_whitelisted_ips
        expect(actual).to be_a(
          IpAccessManagement::WhitelistedIps
        )
        actual.result.each do |whitelisted_ip|
          expect(whitelisted_ip).to be_a(
            IpAccessManagement::WhitelistedIpResult
          )
        end
      end

      it '#post_whitelisted_ips' do
        allow(client).to receive(:execute).and_return(whitelisted_ips)
        actual = client.post_whitelisted_ips(ips: [''])
        expect(actual).to be_a(
          IpAccessManagement::WhitelistedIps
        )
        actual.result.each do |whitelisted_ip|
          expect(whitelisted_ip).to be_a(
            IpAccessManagement::WhitelistedIpResult
          )
        end
      end

      it '#delete_whitelisted_ips' do
        allow(client).to receive(:execute).and_return('')
        actual = client.delete_whitelisted_ips(ids: [''])
        expect(actual).to eq('')
      end

      it '#get_whitelisted_ip' do
        allow(client).to receive(:execute).and_return(whitelisted_ip)
        actual = client.get_whitelisted_ip(rule_id: '')
        expect(actual).to be_a(
          IpAccessManagement::WhitelistedIp
        )
      end

      it '#delete_whitelisted_ip' do
        allow(client).to receive(:execute).and_return('')
        actual = client.delete_whitelisted_ip(rule_id: '')
        expect(actual).to eq('')
      end

      it 'creates ip_activities instance' do
        actual = IpAccessManagement.create_ip_activities(
          JSON.parse(ip_activities)
        )
        expect(actual.result.length).to eq(2)
        activity0 = actual.result[0]
        expect(activity0.allowed).to eq(false)
        expect(activity0.auth_method).to eq('basic')
        expect(activity0.first_at).to eq(Time.at(1444087966))
        expect(activity0.ip).to eq('1.1.1.1')
        expect(activity0.last_at).to eq(Time.at(1444406672))
        expect(activity0.location).to eq('Australia')
      end

      it 'creates whitelisted_ips instance' do
        actual = IpAccessManagement.create_whitelisted_ips(
          JSON.parse(whitelisted_ips)
        )
        expect(actual.result.length).to eq(3)
        ip1 = actual.result[0]
        expect(ip1.id).to eq(1)
        expect(ip1.ip).to eq('192.168.1.1/32')
        expect(ip1.created_at).to eq(Time.at(1441824715))
        expect(ip1.updated_at).to eq(Time.at(1441824715))
      end

      it 'creates whitelisted_ip instance' do
        actual = IpAccessManagement.create_whitelisted_ip(
          JSON.parse(whitelisted_ip)
        )
        expect(actual.result.id).to eq(1)
        expect(actual.result.ip).to eq('192.168.1.1/32')
        expect(actual.result.created_at).to eq(Time.at(1459011215))
        expect(actual.result.updated_at).to eq(Time.at(1459011215))
      end
    end
  end
end