aboutsummaryrefslogtreecommitdiffstats
path: root/mso-api-handlers/mso-api-handler-common/src/main/java
diff options
context:
space:
mode:
authorArthur Martella <am153x@att.com>2018-05-31 00:37:17 -0400
committerMarcus Williams <marcus.williams@intel.com>2018-07-20 19:53:26 +0000
commit132245d1dd9a8b174086460dc47dfe13d086cfff (patch)
treebe83523b4a1fed1010e9d2101db2b1cc07bedce7 /mso-api-handlers/mso-api-handler-common/src/main/java
parent0b5d1c2bb8aa47ae582bb7d4153b220c4a81fc5f (diff)
Update docker image name to onap/so
Change-Id: I09b32b08d13053643c65e41bdb40c146df8328ed Issue-ID: SO-601 Signed-off-by: Arthur Martella <am153x@att.com>
Diffstat (limited to 'mso-api-handlers/mso-api-handler-common/src/main/java')
0 files changed, 0 insertions, 0 deletions
highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
/*-
 * ============LICENSE_START=======================================================
 * ONAP POLICY-CLAMP
 * ================================================================================
 * Copyright (C) 2020-2021 AT&T Intellectual Property. All rights
 *                             reserved.
 * ================================================================================
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============LICENSE_END============================================
 * ===================================================================
 *
 */
import React from 'react';
import { mount } from 'enzyme';
import PolicyModal from './PolicyModal';
import LoopCache from '../../../api/LoopCache';
import LoopService from '../../../api/LoopService';
import OnapConstant from '../../../utils/OnapConstants';
import { shallow } from 'enzyme';

describe('Verify PolicyModal', () => {
  beforeEach(() => {
    fetch.resetMocks();
    fetch.mockImplementation(() => {
      return Promise.resolve({
        ok: true,
        status: 200,
        text: () => "OK"
      });
    });
  })
  const loopCacheStr = {
    "name": "LOOP_Jbv1z_v1_0_ResourceInstanceName1_tca",
    "operationalPolicies": [{
      "name": "OPERATIONAL_h2NMX_v1_0_ResourceInstanceName1_tca",
      "configurationsJson": {
        "operational_policy": {
          "controlLoop": {},
          "policies": []
        }
      },
      "policyModel": { "policyPdpGroup": { "supportedPdpGroups": [{ "monitoring": ["xacml"] }] } },
      "jsonRepresentation": { "schema": {} }
    }]
  };

  const loopCache = new LoopCache(loopCacheStr);
  const historyMock = { push: jest.fn() };
  const flushPromises = () => new Promise(setImmediate);
  const match = { params: { policyName: "OPERATIONAL_h2NMX_v1_0_ResourceInstanceName1_tca", policyInstanceType: OnapConstant.operationalPolicyType } }

  it('Test handleClose', () => {
    const handleClose = jest.spyOn(PolicyModal.prototype, 'handleClose');
    const component = mount(<PolicyModal history={ historyMock } match={ match } loopCache={ loopCache }/>)

    component.find('[variant="secondary"]').prop('onClick')();

    expect(handleClose).toHaveBeenCalledTimes(1);
    expect(component.state('show')).toEqual(false);
    expect(historyMock.push.mock.calls[0]).toEqual(['/']);
  });

  it('Test handleSave', async () => {
    const loadLoopFunction = jest.fn();
    const handleSave = jest.spyOn(PolicyModal.prototype, 'handleSave');
    const component = mount(<PolicyModal history={ historyMock }
                                         loopCache={ loopCache } match={ match } loadLoopFunction={ loadLoopFunction }/>)

    component.find('[variant="primary"]').get(0).props.onClick();
    await flushPromises();
    component.update();

    expect(handleSave).toHaveBeenCalledTimes(1);
    expect(component.state('show')).toEqual(false);
    expect(historyMock.push.mock.calls[0]).toEqual(['/']);
  });

  it('Test handleRefresh', async () => {
    LoopService.refreshOperationalPolicyJson = jest.fn().mockImplementation(() => {
      return Promise.resolve(loopCacheStr);
    });
    const updateLoopFunction = jest.fn();
    const handleRefresh = jest.spyOn(PolicyModal.prototype, 'handleRefresh');
    const component = mount(<PolicyModal loopCache={ loopCache } match={ match } updateLoopFunction={ updateLoopFunction }/>)

    component.find('[variant="primary"]').get(1).props.onClick();
    await flushPromises();
    component.update();

    expect(handleRefresh).toHaveBeenCalledTimes(1);
    expect(component.state('show')).toEqual(true);
    expect(component.state('showSucAlert')).toEqual(true);
    expect(component.state('showMessage')).toEqual("Successfully refreshed");
  });

  it('Test handlePdpGroupChange', () => {
    const component = mount(<PolicyModal loopCache={ loopCache } match={ match }/>)
    component.setState({
      "pdpGroup": [{ "option1": ["subPdp1", "subPdp2"] }],
      "chosenPdpGroup": "option2"
    });
    expect(component.state('chosenPdpGroup')).toEqual("option2");

    const instance = component.instance();
    const event = { label: "option1", value: "option1" }
    instance.handlePdpGroupChange(event);
    expect(component.state('chosenPdpGroup')).toEqual("option1");
    expect(component.state('chosenPdpSubgroup')).toEqual("");
    expect(component.state('pdpSubgroupList')).toEqual([{ label: "subPdp1", value: "subPdp1" }, { label: "subPdp2", value: "subPdp2" }]);
  });

  it('Test handlePdpSubgroupChange', () => {
    const component = mount(<PolicyModal loopCache={ loopCache } match={ match }/>)

    const instance = component.instance();
    const event = { label: "option1", value: "option1" }
    instance.handlePdpSubgroupChange(event);
    expect(component.state('chosenPdpSubgroup')).toEqual("option1");
  });

  it('Test the render method', () => {
    const component = shallow(<PolicyModal loopCache={ loopCache } match={ match }/>)
    expect(component).toMatchSnapshot();
  });
});